| // Code generated by protoc-gen-go. | 
 | // source: google/protobuf/compiler/plugin.proto | 
 | // DO NOT EDIT! | 
 |  | 
 | /* | 
 | Package plugin_go is a generated protocol buffer package. | 
 |  | 
 | It is generated from these files: | 
 | 	google/protobuf/compiler/plugin.proto | 
 |  | 
 | It has these top-level messages: | 
 | 	CodeGeneratorRequest | 
 | 	CodeGeneratorResponse | 
 | */ | 
 | package plugin_go | 
 |  | 
 | import proto "github.com/golang/protobuf/proto" | 
 | import fmt "fmt" | 
 | import math "math" | 
 | import google_protobuf "github.com/golang/protobuf/protoc-gen-go/descriptor" | 
 |  | 
 | // Reference imports to suppress errors if they are not otherwise used. | 
 | var _ = proto.Marshal | 
 | var _ = fmt.Errorf | 
 | var _ = math.Inf | 
 |  | 
 | // This is a compile-time assertion to ensure that this generated file | 
 | // is compatible with the proto package it is being compiled against. | 
 | const _ = proto.ProtoPackageIsVersion1 | 
 |  | 
 | // An encoded CodeGeneratorRequest is written to the plugin's stdin. | 
 | type CodeGeneratorRequest struct { | 
 | 	// The .proto files that were explicitly listed on the command-line.  The | 
 | 	// code generator should generate code only for these files.  Each file's | 
 | 	// descriptor will be included in proto_file, below. | 
 | 	FileToGenerate []string `protobuf:"bytes,1,rep,name=file_to_generate,json=fileToGenerate" json:"file_to_generate,omitempty"` | 
 | 	// The generator parameter passed on the command-line. | 
 | 	Parameter *string `protobuf:"bytes,2,opt,name=parameter" json:"parameter,omitempty"` | 
 | 	// FileDescriptorProtos for all files in files_to_generate and everything | 
 | 	// they import.  The files will appear in topological order, so each file | 
 | 	// appears before any file that imports it. | 
 | 	// | 
 | 	// protoc guarantees that all proto_files will be written after | 
 | 	// the fields above, even though this is not technically guaranteed by the | 
 | 	// protobuf wire format.  This theoretically could allow a plugin to stream | 
 | 	// in the FileDescriptorProtos and handle them one by one rather than read | 
 | 	// the entire set into memory at once.  However, as of this writing, this | 
 | 	// is not similarly optimized on protoc's end -- it will store all fields in | 
 | 	// memory at once before sending them to the plugin. | 
 | 	ProtoFile        []*google_protobuf.FileDescriptorProto `protobuf:"bytes,15,rep,name=proto_file,json=protoFile" json:"proto_file,omitempty"` | 
 | 	XXX_unrecognized []byte                                 `json:"-"` | 
 | } | 
 |  | 
 | func (m *CodeGeneratorRequest) Reset()                    { *m = CodeGeneratorRequest{} } | 
 | func (m *CodeGeneratorRequest) String() string            { return proto.CompactTextString(m) } | 
 | func (*CodeGeneratorRequest) ProtoMessage()               {} | 
 | func (*CodeGeneratorRequest) Descriptor() ([]byte, []int) { return fileDescriptor0, []int{0} } | 
 |  | 
 | func (m *CodeGeneratorRequest) GetFileToGenerate() []string { | 
 | 	if m != nil { | 
 | 		return m.FileToGenerate | 
 | 	} | 
 | 	return nil | 
 | } | 
 |  | 
 | func (m *CodeGeneratorRequest) GetParameter() string { | 
 | 	if m != nil && m.Parameter != nil { | 
 | 		return *m.Parameter | 
 | 	} | 
 | 	return "" | 
 | } | 
 |  | 
 | func (m *CodeGeneratorRequest) GetProtoFile() []*google_protobuf.FileDescriptorProto { | 
 | 	if m != nil { | 
 | 		return m.ProtoFile | 
 | 	} | 
 | 	return nil | 
 | } | 
 |  | 
 | // The plugin writes an encoded CodeGeneratorResponse to stdout. | 
 | type CodeGeneratorResponse struct { | 
 | 	// Error message.  If non-empty, code generation failed.  The plugin process | 
 | 	// should exit with status code zero even if it reports an error in this way. | 
 | 	// | 
 | 	// This should be used to indicate errors in .proto files which prevent the | 
 | 	// code generator from generating correct code.  Errors which indicate a | 
 | 	// problem in protoc itself -- such as the input CodeGeneratorRequest being | 
 | 	// unparseable -- should be reported by writing a message to stderr and | 
 | 	// exiting with a non-zero status code. | 
 | 	Error            *string                       `protobuf:"bytes,1,opt,name=error" json:"error,omitempty"` | 
 | 	File             []*CodeGeneratorResponse_File `protobuf:"bytes,15,rep,name=file" json:"file,omitempty"` | 
 | 	XXX_unrecognized []byte                        `json:"-"` | 
 | } | 
 |  | 
 | func (m *CodeGeneratorResponse) Reset()                    { *m = CodeGeneratorResponse{} } | 
 | func (m *CodeGeneratorResponse) String() string            { return proto.CompactTextString(m) } | 
 | func (*CodeGeneratorResponse) ProtoMessage()               {} | 
 | func (*CodeGeneratorResponse) Descriptor() ([]byte, []int) { return fileDescriptor0, []int{1} } | 
 |  | 
 | func (m *CodeGeneratorResponse) GetError() string { | 
 | 	if m != nil && m.Error != nil { | 
 | 		return *m.Error | 
 | 	} | 
 | 	return "" | 
 | } | 
 |  | 
 | func (m *CodeGeneratorResponse) GetFile() []*CodeGeneratorResponse_File { | 
 | 	if m != nil { | 
 | 		return m.File | 
 | 	} | 
 | 	return nil | 
 | } | 
 |  | 
 | // Represents a single generated file. | 
 | type CodeGeneratorResponse_File struct { | 
 | 	// The file name, relative to the output directory.  The name must not | 
 | 	// contain "." or ".." components and must be relative, not be absolute (so, | 
 | 	// the file cannot lie outside the output directory).  "/" must be used as | 
 | 	// the path separator, not "\". | 
 | 	// | 
 | 	// If the name is omitted, the content will be appended to the previous | 
 | 	// file.  This allows the generator to break large files into small chunks, | 
 | 	// and allows the generated text to be streamed back to protoc so that large | 
 | 	// files need not reside completely in memory at one time.  Note that as of | 
 | 	// this writing protoc does not optimize for this -- it will read the entire | 
 | 	// CodeGeneratorResponse before writing files to disk. | 
 | 	Name *string `protobuf:"bytes,1,opt,name=name" json:"name,omitempty"` | 
 | 	// If non-empty, indicates that the named file should already exist, and the | 
 | 	// content here is to be inserted into that file at a defined insertion | 
 | 	// point.  This feature allows a code generator to extend the output | 
 | 	// produced by another code generator.  The original generator may provide | 
 | 	// insertion points by placing special annotations in the file that look | 
 | 	// like: | 
 | 	//   @@protoc_insertion_point(NAME) | 
 | 	// The annotation can have arbitrary text before and after it on the line, | 
 | 	// which allows it to be placed in a comment.  NAME should be replaced with | 
 | 	// an identifier naming the point -- this is what other generators will use | 
 | 	// as the insertion_point.  Code inserted at this point will be placed | 
 | 	// immediately above the line containing the insertion point (thus multiple | 
 | 	// insertions to the same point will come out in the order they were added). | 
 | 	// The double-@ is intended to make it unlikely that the generated code | 
 | 	// could contain things that look like insertion points by accident. | 
 | 	// | 
 | 	// For example, the C++ code generator places the following line in the | 
 | 	// .pb.h files that it generates: | 
 | 	//   // @@protoc_insertion_point(namespace_scope) | 
 | 	// This line appears within the scope of the file's package namespace, but | 
 | 	// outside of any particular class.  Another plugin can then specify the | 
 | 	// insertion_point "namespace_scope" to generate additional classes or | 
 | 	// other declarations that should be placed in this scope. | 
 | 	// | 
 | 	// Note that if the line containing the insertion point begins with | 
 | 	// whitespace, the same whitespace will be added to every line of the | 
 | 	// inserted text.  This is useful for languages like Python, where | 
 | 	// indentation matters.  In these languages, the insertion point comment | 
 | 	// should be indented the same amount as any inserted code will need to be | 
 | 	// in order to work correctly in that context. | 
 | 	// | 
 | 	// The code generator that generates the initial file and the one which | 
 | 	// inserts into it must both run as part of a single invocation of protoc. | 
 | 	// Code generators are executed in the order in which they appear on the | 
 | 	// command line. | 
 | 	// | 
 | 	// If |insertion_point| is present, |name| must also be present. | 
 | 	InsertionPoint *string `protobuf:"bytes,2,opt,name=insertion_point,json=insertionPoint" json:"insertion_point,omitempty"` | 
 | 	// The file contents. | 
 | 	Content          *string `protobuf:"bytes,15,opt,name=content" json:"content,omitempty"` | 
 | 	XXX_unrecognized []byte  `json:"-"` | 
 | } | 
 |  | 
 | func (m *CodeGeneratorResponse_File) Reset()                    { *m = CodeGeneratorResponse_File{} } | 
 | func (m *CodeGeneratorResponse_File) String() string            { return proto.CompactTextString(m) } | 
 | func (*CodeGeneratorResponse_File) ProtoMessage()               {} | 
 | func (*CodeGeneratorResponse_File) Descriptor() ([]byte, []int) { return fileDescriptor0, []int{1, 0} } | 
 |  | 
 | func (m *CodeGeneratorResponse_File) GetName() string { | 
 | 	if m != nil && m.Name != nil { | 
 | 		return *m.Name | 
 | 	} | 
 | 	return "" | 
 | } | 
 |  | 
 | func (m *CodeGeneratorResponse_File) GetInsertionPoint() string { | 
 | 	if m != nil && m.InsertionPoint != nil { | 
 | 		return *m.InsertionPoint | 
 | 	} | 
 | 	return "" | 
 | } | 
 |  | 
 | func (m *CodeGeneratorResponse_File) GetContent() string { | 
 | 	if m != nil && m.Content != nil { | 
 | 		return *m.Content | 
 | 	} | 
 | 	return "" | 
 | } | 
 |  | 
 | func init() { | 
 | 	proto.RegisterType((*CodeGeneratorRequest)(nil), "google.protobuf.compiler.CodeGeneratorRequest") | 
 | 	proto.RegisterType((*CodeGeneratorResponse)(nil), "google.protobuf.compiler.CodeGeneratorResponse") | 
 | 	proto.RegisterType((*CodeGeneratorResponse_File)(nil), "google.protobuf.compiler.CodeGeneratorResponse.File") | 
 | } | 
 |  | 
 | var fileDescriptor0 = []byte{ | 
 | 	// 311 bytes of a gzipped FileDescriptorProto | 
 | 	0x1f, 0x8b, 0x08, 0x00, 0x00, 0x09, 0x6e, 0x88, 0x02, 0xff, 0x74, 0x91, 0xd1, 0x4a, 0xfb, 0x30, | 
 | 	0x14, 0xc6, 0xe9, 0xff, 0x3f, 0x91, 0x1d, 0x65, 0x93, 0x30, 0xa1, 0x8c, 0x5d, 0x94, 0xa1, 0xb8, | 
 | 	0xab, 0x14, 0x44, 0xf0, 0x7e, 0x13, 0xf5, 0xb2, 0x14, 0xaf, 0x04, 0x29, 0xb5, 0x3b, 0x2b, 0x81, | 
 | 	0x2e, 0x27, 0xa6, 0xe9, 0x13, 0xf9, 0x4e, 0x3e, 0x8f, 0x49, 0xda, 0x4e, 0x29, 0xee, 0xaa, 0x3d, | 
 | 	0xdf, 0xf9, 0xe5, 0x3b, 0x5f, 0x72, 0xe0, 0xba, 0x24, 0x2a, 0x2b, 0x8c, 0x95, 0x26, 0x43, 0xef, | 
 | 	0xcd, 0x2e, 0x2e, 0x68, 0xaf, 0x44, 0x85, 0x3a, 0x56, 0x55, 0x53, 0x0a, 0xc9, 0x7d, 0x83, 0x85, | 
 | 	0x2d, 0xc6, 0x7b, 0x8c, 0xf7, 0xd8, 0x3c, 0x1a, 0x1a, 0x6c, 0xb1, 0x2e, 0xb4, 0x50, 0x86, 0x74, | 
 | 	0x4b, 0x2f, 0x3f, 0x03, 0x98, 0x6d, 0x68, 0x8b, 0x4f, 0x28, 0x51, 0xe7, 0x56, 0x4f, 0xf1, 0xa3, | 
 | 	0xc1, 0xda, 0xb0, 0x15, 0x5c, 0xec, 0xac, 0x47, 0x66, 0x28, 0x2b, 0xdb, 0x1e, 0x86, 0x41, 0xf4, | 
 | 	0x7f, 0x35, 0x4e, 0x27, 0x4e, 0x7f, 0xa1, 0xee, 0x04, 0xb2, 0x05, 0x8c, 0x55, 0xae, 0xf3, 0x3d, | 
 | 	0x1a, 0xd4, 0xe1, 0xbf, 0x28, 0xb0, 0xc8, 0x8f, 0xc0, 0x36, 0x00, 0x7e, 0x52, 0xe6, 0x4e, 0x85, | 
 | 	0x53, 0xeb, 0x70, 0x76, 0x7b, 0xc5, 0x87, 0x89, 0x1f, 0x6d, 0xf3, 0xe1, 0x90, 0x2d, 0x71, 0xb2, | 
 | 	0x35, 0x71, 0x1f, 0xd7, 0x59, 0x7e, 0x05, 0x70, 0x39, 0x48, 0x59, 0x2b, 0x92, 0x35, 0xb2, 0x19, | 
 | 	0x9c, 0xa0, 0xd6, 0xa4, 0x6d, 0x36, 0x37, 0xb8, 0x2d, 0xd8, 0x33, 0x8c, 0x7e, 0x8d, 0xbb, 0xe3, | 
 | 	0xc7, 0x1e, 0x88, 0xff, 0x69, 0xea, 0xd3, 0xa4, 0xde, 0x61, 0xfe, 0x06, 0x23, 0x57, 0x31, 0x06, | 
 | 	0x23, 0x69, 0x6f, 0xd4, 0x8d, 0xf1, 0xff, 0xec, 0x06, 0xa6, 0xc2, 0xe2, 0xda, 0x08, 0x92, 0x99, | 
 | 	0x22, 0x21, 0x4d, 0x77, 0xfd, 0xc9, 0x41, 0x4e, 0x9c, 0xca, 0x42, 0x38, 0x2d, 0x48, 0x1a, 0xb4, | 
 | 	0xc0, 0xd4, 0x03, 0x7d, 0xb9, 0xbe, 0x87, 0x85, 0xcd, 0x72, 0x34, 0xdf, 0xfa, 0x3c, 0xf1, 0x8b, | 
 | 	0xf6, 0x0f, 0x52, 0xbf, 0x8e, 0xdb, 0xb5, 0x67, 0x25, 0x7d, 0x07, 0x00, 0x00, 0xff, 0xff, 0x83, | 
 | 	0x7b, 0x5c, 0x7c, 0x1b, 0x02, 0x00, 0x00, | 
 | } |