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

Unified Diff: mojo/public/tools/bindings/generators/go_templates/interface.tmpl

Issue 1345263002: Generate Mojom Types in Go (Closed) Base URL: https://github.com/domokit/mojo.git@master
Patch Set: Address Naming changes and Comment Updates Created 5 years, 2 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: mojo/public/tools/bindings/generators/go_templates/interface.tmpl
diff --git a/mojo/public/tools/bindings/generators/go_templates/interface.tmpl b/mojo/public/tools/bindings/generators/go_templates/interface.tmpl
index 1b9160f82d05f4b50017b523482c9f1ea3ba09f9..403a4414eaaf2ea4c02c847dc15798901a0d453a 100644
--- a/mojo/public/tools/bindings/generators/go_templates/interface.tmpl
+++ b/mojo/public/tools/bindings/generators/go_templates/interface.tmpl
@@ -3,6 +3,7 @@
// found in the LICENSE file.
{% import "struct.tmpl" as struct_macros %}
+{% import "mojom_type_macros.tmpl" as mojom_type_macros %}
{%- macro declare_params(struct) %}
{%- for field in struct.fields -%}
@@ -35,7 +36,7 @@
-{% macro define(interface) %}
+{% macro define(interface, descpkg, typepkg, pkg) %}
type {{interface|name}} interface {
{% for method in interface.methods %}
{{method|name}}{{declare_request_params(method)}}
@@ -68,6 +69,10 @@ func (f *{{interface|name}}_ServiceFactory) Name() string {
return {{interface|name(False)}}_Name
}
+func (f *{{interface|name}}_ServiceFactory) ServiceDescription() {{descpkg}}ServiceDescription {
+ return &{{interface|name}}_ServiceDescription{}
+}
+
func (f *{{interface|name}}_ServiceFactory) Create(messagePipe system.MessagePipeHandle) {
request := {{interface|name}}_Request{bindings.NewMessagePipeHandleOwner(messagePipe)}
f.Delegate.Create(request)
@@ -101,9 +106,9 @@ func (p *{{interface|name}}_Proxy) Close_Proxy() {
}
{% for method in interface.methods %}
-{{struct_macros.define(method.param_struct, False)}}
+{{struct_macros.define(method.param_struct, typepkg, pkg, False)}}
{%- if method|has_response %}
-{{struct_macros.define(method.response_param_struct, False)}}
+{{struct_macros.define(method.response_param_struct, typepkg, pkg, False)}}
{%- endif %}
func (p *{{interface|name}}_Proxy) {{method|name}}{{declare_request_params(method)}} {
payload := &{{method.param_struct|name(False)}}{
@@ -170,6 +175,51 @@ func New{{interface|name}}Stub(r {{interface|name}}_Request, impl {{interface|na
return bindings.NewStub(connector, &{{interface|name(False)}}_Stub{connector, impl})
}
+{{ mojom_type_macros.writeMojomTypeDef(typepkg, interface, pkg, exported) }}
+
+func (f *{{interface|name}}_Request) ServiceDescription() {{descpkg}}ServiceDescription {
+ return &{{interface|name}}_ServiceDescription{}
+}
+
+
+type {{interface|name}}_ServiceDescription struct{}
+
+{% if should_gen_mojom_types -%}
+func (sd *{{interface|name}}_ServiceDescription) GetTopLevelInterface() (outMojomInterface {{typepkg}}MojomInterface, err error) {
+ return {{interface|mojom_type_identifier}}(), nil
+}
+
+func (sd *{{interface|name}}_ServiceDescription) GetTypeDefinition(inTypeKey string) (outType mojom_types.UserDefinedType, err error) {
+ if udt, ok := GetAllMojomTypeDefinitions()[inTypeKey]; ok {
+ return udt, nil
+ }
+ return nil, fmt.Errorf("%s_ServiceDescription does not recognize %s", "{{interface|name}}", inTypeKey)
+}
+
+func (sd *{{interface|name}}_ServiceDescription) GetAllTypeDefinitions() (outDefinitions *map[string]mojom_types.UserDefinedType, err error) {
+ o := GetAllMojomTypeDefinitions()
+ return &o, nil
+}
+{%- else -%}
+func (sd *{{interface|name}}_ServiceDescription) GetTopLevelInterface() (outMojomInterface {{typepkg}}MojomInterface, err error) {
+ err = fmt.Errorf("GetTopLevelInterface not implemented")
+ return
+}
+
+func (sd *{{interface|name}}_ServiceDescription) GetTypeDefinition(inTypeKey string) (outType mojom_types.UserDefinedType, err error) {
+ err = fmt.Errorf("GetTypeDefinition not implemented")
+ return
+}
+
+func (sd *{{interface|name}}_ServiceDescription) GetAllTypeDefinitions() (outDefinitions *map[string]mojom_types.UserDefinedType, err error) {
+ err = fmt.Errorf("GetAllTypeDefinitions not implemented")
+ return
+}
+{%- endif %}
+
+var _ {{descpkg}}ServiceDescription = (*{{interface|name}}_ServiceDescription)(nil)
+
+
func (s *{{interface|name(False)}}_Stub) Accept(message *bindings.Message) (err error) {
switch message.Header.Type {
{% for method in interface.methods %}

Powered by Google App Engine
This is Rietveld 408576698