All Downloads are FREE. Search and download functionalities are using the official Maven repository.

com.google.protobuf.compiler.PluginProtos Maven / Gradle / Ivy

There is a newer version: 2.0.31
Show newest version
// Generated by the protocol buffer compiler.  DO NOT EDIT!
// source: google/protobuf/compiler/plugin.proto

package com.google.protobuf.compiler;

public final class PluginProtos {
  private PluginProtos() {}
  public static void registerAllExtensions(
      com.google.protobuf.ExtensionRegistryLite registry) {
  }

  public static void registerAllExtensions(
      com.google.protobuf.ExtensionRegistry registry) {
    registerAllExtensions(
        (com.google.protobuf.ExtensionRegistryLite) registry);
  }
  public interface VersionOrBuilder extends
      // @@protoc_insertion_point(interface_extends:google.protobuf.compiler.Version)
      com.google.protobuf.MessageOrBuilder {

    /**
     * optional int32 major = 1;
     * @return Whether the major field is set.
     */
    boolean hasMajor();
    /**
     * optional int32 major = 1;
     * @return The major.
     */
    int getMajor();

    /**
     * optional int32 minor = 2;
     * @return Whether the minor field is set.
     */
    boolean hasMinor();
    /**
     * optional int32 minor = 2;
     * @return The minor.
     */
    int getMinor();

    /**
     * optional int32 patch = 3;
     * @return Whether the patch field is set.
     */
    boolean hasPatch();
    /**
     * optional int32 patch = 3;
     * @return The patch.
     */
    int getPatch();

    /**
     * 
     * A suffix for alpha, beta or rc release, e.g., "alpha-1", "rc2". It should
     * be empty for mainline stable releases.
     * 
* * optional string suffix = 4; * @return Whether the suffix field is set. */ boolean hasSuffix(); /** *
     * A suffix for alpha, beta or rc release, e.g., "alpha-1", "rc2". It should
     * be empty for mainline stable releases.
     * 
* * optional string suffix = 4; * @return The suffix. */ java.lang.String getSuffix(); /** *
     * A suffix for alpha, beta or rc release, e.g., "alpha-1", "rc2". It should
     * be empty for mainline stable releases.
     * 
* * optional string suffix = 4; * @return The bytes for suffix. */ com.google.protobuf.ByteString getSuffixBytes(); } /** *
   * The version number of protocol compiler.
   * 
* * Protobuf type {@code google.protobuf.compiler.Version} */ public static final class Version extends com.google.protobuf.GeneratedMessageV3 implements // @@protoc_insertion_point(message_implements:google.protobuf.compiler.Version) VersionOrBuilder { private static final long serialVersionUID = 0L; // Use Version.newBuilder() to construct. private Version(com.google.protobuf.GeneratedMessageV3.Builder builder) { super(builder); } private Version() { suffix_ = ""; } @java.lang.Override @SuppressWarnings({"unused"}) protected java.lang.Object newInstance( UnusedPrivateParameter unused) { return new Version(); } @java.lang.Override public final com.google.protobuf.UnknownFieldSet getUnknownFields() { return this.unknownFields; } public static final com.google.protobuf.Descriptors.Descriptor getDescriptor() { return com.google.protobuf.compiler.PluginProtos.internal_static_google_protobuf_compiler_Version_descriptor; } @java.lang.Override protected com.google.protobuf.GeneratedMessageV3.FieldAccessorTable internalGetFieldAccessorTable() { return com.google.protobuf.compiler.PluginProtos.internal_static_google_protobuf_compiler_Version_fieldAccessorTable .ensureFieldAccessorsInitialized( com.google.protobuf.compiler.PluginProtos.Version.class, com.google.protobuf.compiler.PluginProtos.Version.Builder.class); } private int bitField0_; public static final int MAJOR_FIELD_NUMBER = 1; private int major_ = 0; /** * optional int32 major = 1; * @return Whether the major field is set. */ @java.lang.Override public boolean hasMajor() { return ((bitField0_ & 0x00000001) != 0); } /** * optional int32 major = 1; * @return The major. */ @java.lang.Override public int getMajor() { return major_; } public static final int MINOR_FIELD_NUMBER = 2; private int minor_ = 0; /** * optional int32 minor = 2; * @return Whether the minor field is set. */ @java.lang.Override public boolean hasMinor() { return ((bitField0_ & 0x00000002) != 0); } /** * optional int32 minor = 2; * @return The minor. */ @java.lang.Override public int getMinor() { return minor_; } public static final int PATCH_FIELD_NUMBER = 3; private int patch_ = 0; /** * optional int32 patch = 3; * @return Whether the patch field is set. */ @java.lang.Override public boolean hasPatch() { return ((bitField0_ & 0x00000004) != 0); } /** * optional int32 patch = 3; * @return The patch. */ @java.lang.Override public int getPatch() { return patch_; } public static final int SUFFIX_FIELD_NUMBER = 4; @SuppressWarnings("serial") private volatile java.lang.Object suffix_ = ""; /** *
     * A suffix for alpha, beta or rc release, e.g., "alpha-1", "rc2". It should
     * be empty for mainline stable releases.
     * 
* * optional string suffix = 4; * @return Whether the suffix field is set. */ @java.lang.Override public boolean hasSuffix() { return ((bitField0_ & 0x00000008) != 0); } /** *
     * A suffix for alpha, beta or rc release, e.g., "alpha-1", "rc2". It should
     * be empty for mainline stable releases.
     * 
* * optional string suffix = 4; * @return The suffix. */ @java.lang.Override public java.lang.String getSuffix() { java.lang.Object ref = suffix_; if (ref instanceof java.lang.String) { return (java.lang.String) ref; } else { com.google.protobuf.ByteString bs = (com.google.protobuf.ByteString) ref; java.lang.String s = bs.toStringUtf8(); if (bs.isValidUtf8()) { suffix_ = s; } return s; } } /** *
     * A suffix for alpha, beta or rc release, e.g., "alpha-1", "rc2". It should
     * be empty for mainline stable releases.
     * 
* * optional string suffix = 4; * @return The bytes for suffix. */ @java.lang.Override public com.google.protobuf.ByteString getSuffixBytes() { java.lang.Object ref = suffix_; if (ref instanceof java.lang.String) { com.google.protobuf.ByteString b = com.google.protobuf.ByteString.copyFromUtf8( (java.lang.String) ref); suffix_ = b; return b; } else { return (com.google.protobuf.ByteString) ref; } } private byte memoizedIsInitialized = -1; @java.lang.Override public final boolean isInitialized() { byte isInitialized = memoizedIsInitialized; if (isInitialized == 1) return true; if (isInitialized == 0) return false; memoizedIsInitialized = 1; return true; } @java.lang.Override public void writeTo(com.google.protobuf.CodedOutputStream output) throws java.io.IOException { if (((bitField0_ & 0x00000001) != 0)) { output.writeInt32(1, major_); } if (((bitField0_ & 0x00000002) != 0)) { output.writeInt32(2, minor_); } if (((bitField0_ & 0x00000004) != 0)) { output.writeInt32(3, patch_); } if (((bitField0_ & 0x00000008) != 0)) { com.google.protobuf.GeneratedMessageV3.writeString(output, 4, suffix_); } getUnknownFields().writeTo(output); } @java.lang.Override public int getSerializedSize() { int size = memoizedSize; if (size != -1) return size; size = 0; if (((bitField0_ & 0x00000001) != 0)) { size += com.google.protobuf.CodedOutputStream .computeInt32Size(1, major_); } if (((bitField0_ & 0x00000002) != 0)) { size += com.google.protobuf.CodedOutputStream .computeInt32Size(2, minor_); } if (((bitField0_ & 0x00000004) != 0)) { size += com.google.protobuf.CodedOutputStream .computeInt32Size(3, patch_); } if (((bitField0_ & 0x00000008) != 0)) { size += com.google.protobuf.GeneratedMessageV3.computeStringSize(4, suffix_); } size += getUnknownFields().getSerializedSize(); memoizedSize = size; return size; } @java.lang.Override public boolean equals(final java.lang.Object obj) { if (obj == this) { return true; } if (!(obj instanceof com.google.protobuf.compiler.PluginProtos.Version)) { return super.equals(obj); } com.google.protobuf.compiler.PluginProtos.Version other = (com.google.protobuf.compiler.PluginProtos.Version) obj; if (hasMajor() != other.hasMajor()) return false; if (hasMajor()) { if (getMajor() != other.getMajor()) return false; } if (hasMinor() != other.hasMinor()) return false; if (hasMinor()) { if (getMinor() != other.getMinor()) return false; } if (hasPatch() != other.hasPatch()) return false; if (hasPatch()) { if (getPatch() != other.getPatch()) return false; } if (hasSuffix() != other.hasSuffix()) return false; if (hasSuffix()) { if (!getSuffix() .equals(other.getSuffix())) return false; } if (!getUnknownFields().equals(other.getUnknownFields())) return false; return true; } @java.lang.Override public int hashCode() { if (memoizedHashCode != 0) { return memoizedHashCode; } int hash = 41; hash = (19 * hash) + getDescriptor().hashCode(); if (hasMajor()) { hash = (37 * hash) + MAJOR_FIELD_NUMBER; hash = (53 * hash) + getMajor(); } if (hasMinor()) { hash = (37 * hash) + MINOR_FIELD_NUMBER; hash = (53 * hash) + getMinor(); } if (hasPatch()) { hash = (37 * hash) + PATCH_FIELD_NUMBER; hash = (53 * hash) + getPatch(); } if (hasSuffix()) { hash = (37 * hash) + SUFFIX_FIELD_NUMBER; hash = (53 * hash) + getSuffix().hashCode(); } hash = (29 * hash) + getUnknownFields().hashCode(); memoizedHashCode = hash; return hash; } public static com.google.protobuf.compiler.PluginProtos.Version parseFrom( java.nio.ByteBuffer data) throws com.google.protobuf.InvalidProtocolBufferException { return PARSER.parseFrom(data); } public static com.google.protobuf.compiler.PluginProtos.Version parseFrom( java.nio.ByteBuffer data, com.google.protobuf.ExtensionRegistryLite extensionRegistry) throws com.google.protobuf.InvalidProtocolBufferException { return PARSER.parseFrom(data, extensionRegistry); } public static com.google.protobuf.compiler.PluginProtos.Version parseFrom( com.google.protobuf.ByteString data) throws com.google.protobuf.InvalidProtocolBufferException { return PARSER.parseFrom(data); } public static com.google.protobuf.compiler.PluginProtos.Version parseFrom( com.google.protobuf.ByteString data, com.google.protobuf.ExtensionRegistryLite extensionRegistry) throws com.google.protobuf.InvalidProtocolBufferException { return PARSER.parseFrom(data, extensionRegistry); } public static com.google.protobuf.compiler.PluginProtos.Version parseFrom(byte[] data) throws com.google.protobuf.InvalidProtocolBufferException { return PARSER.parseFrom(data); } public static com.google.protobuf.compiler.PluginProtos.Version parseFrom( byte[] data, com.google.protobuf.ExtensionRegistryLite extensionRegistry) throws com.google.protobuf.InvalidProtocolBufferException { return PARSER.parseFrom(data, extensionRegistry); } public static com.google.protobuf.compiler.PluginProtos.Version parseFrom(java.io.InputStream input) throws java.io.IOException { return com.google.protobuf.GeneratedMessageV3 .parseWithIOException(PARSER, input); } public static com.google.protobuf.compiler.PluginProtos.Version parseFrom( java.io.InputStream input, com.google.protobuf.ExtensionRegistryLite extensionRegistry) throws java.io.IOException { return com.google.protobuf.GeneratedMessageV3 .parseWithIOException(PARSER, input, extensionRegistry); } public static com.google.protobuf.compiler.PluginProtos.Version parseDelimitedFrom(java.io.InputStream input) throws java.io.IOException { return com.google.protobuf.GeneratedMessageV3 .parseDelimitedWithIOException(PARSER, input); } public static com.google.protobuf.compiler.PluginProtos.Version parseDelimitedFrom( java.io.InputStream input, com.google.protobuf.ExtensionRegistryLite extensionRegistry) throws java.io.IOException { return com.google.protobuf.GeneratedMessageV3 .parseDelimitedWithIOException(PARSER, input, extensionRegistry); } public static com.google.protobuf.compiler.PluginProtos.Version parseFrom( com.google.protobuf.CodedInputStream input) throws java.io.IOException { return com.google.protobuf.GeneratedMessageV3 .parseWithIOException(PARSER, input); } public static com.google.protobuf.compiler.PluginProtos.Version parseFrom( com.google.protobuf.CodedInputStream input, com.google.protobuf.ExtensionRegistryLite extensionRegistry) throws java.io.IOException { return com.google.protobuf.GeneratedMessageV3 .parseWithIOException(PARSER, input, extensionRegistry); } @java.lang.Override public Builder newBuilderForType() { return newBuilder(); } public static Builder newBuilder() { return DEFAULT_INSTANCE.toBuilder(); } public static Builder newBuilder(com.google.protobuf.compiler.PluginProtos.Version prototype) { return DEFAULT_INSTANCE.toBuilder().mergeFrom(prototype); } @java.lang.Override public Builder toBuilder() { return this == DEFAULT_INSTANCE ? new Builder() : new Builder().mergeFrom(this); } @java.lang.Override protected Builder newBuilderForType( com.google.protobuf.GeneratedMessageV3.BuilderParent parent) { Builder builder = new Builder(parent); return builder; } /** *
     * The version number of protocol compiler.
     * 
* * Protobuf type {@code google.protobuf.compiler.Version} */ public static final class Builder extends com.google.protobuf.GeneratedMessageV3.Builder implements // @@protoc_insertion_point(builder_implements:google.protobuf.compiler.Version) com.google.protobuf.compiler.PluginProtos.VersionOrBuilder { public static final com.google.protobuf.Descriptors.Descriptor getDescriptor() { return com.google.protobuf.compiler.PluginProtos.internal_static_google_protobuf_compiler_Version_descriptor; } @java.lang.Override protected com.google.protobuf.GeneratedMessageV3.FieldAccessorTable internalGetFieldAccessorTable() { return com.google.protobuf.compiler.PluginProtos.internal_static_google_protobuf_compiler_Version_fieldAccessorTable .ensureFieldAccessorsInitialized( com.google.protobuf.compiler.PluginProtos.Version.class, com.google.protobuf.compiler.PluginProtos.Version.Builder.class); } // Construct using com.google.protobuf.compiler.PluginProtos.Version.newBuilder() private Builder() { } private Builder( com.google.protobuf.GeneratedMessageV3.BuilderParent parent) { super(parent); } @java.lang.Override public Builder clear() { super.clear(); bitField0_ = 0; major_ = 0; minor_ = 0; patch_ = 0; suffix_ = ""; return this; } @java.lang.Override public com.google.protobuf.Descriptors.Descriptor getDescriptorForType() { return com.google.protobuf.compiler.PluginProtos.internal_static_google_protobuf_compiler_Version_descriptor; } @java.lang.Override public com.google.protobuf.compiler.PluginProtos.Version getDefaultInstanceForType() { return com.google.protobuf.compiler.PluginProtos.Version.getDefaultInstance(); } @java.lang.Override public com.google.protobuf.compiler.PluginProtos.Version build() { com.google.protobuf.compiler.PluginProtos.Version result = buildPartial(); if (!result.isInitialized()) { throw newUninitializedMessageException(result); } return result; } @java.lang.Override public com.google.protobuf.compiler.PluginProtos.Version buildPartial() { com.google.protobuf.compiler.PluginProtos.Version result = new com.google.protobuf.compiler.PluginProtos.Version(this); if (bitField0_ != 0) { buildPartial0(result); } onBuilt(); return result; } private void buildPartial0(com.google.protobuf.compiler.PluginProtos.Version result) { int from_bitField0_ = bitField0_; int to_bitField0_ = 0; if (((from_bitField0_ & 0x00000001) != 0)) { result.major_ = major_; to_bitField0_ |= 0x00000001; } if (((from_bitField0_ & 0x00000002) != 0)) { result.minor_ = minor_; to_bitField0_ |= 0x00000002; } if (((from_bitField0_ & 0x00000004) != 0)) { result.patch_ = patch_; to_bitField0_ |= 0x00000004; } if (((from_bitField0_ & 0x00000008) != 0)) { result.suffix_ = suffix_; to_bitField0_ |= 0x00000008; } result.bitField0_ |= to_bitField0_; } @java.lang.Override public Builder clone() { return super.clone(); } @java.lang.Override public Builder setField( com.google.protobuf.Descriptors.FieldDescriptor field, java.lang.Object value) { return super.setField(field, value); } @java.lang.Override public Builder clearField( com.google.protobuf.Descriptors.FieldDescriptor field) { return super.clearField(field); } @java.lang.Override public Builder clearOneof( com.google.protobuf.Descriptors.OneofDescriptor oneof) { return super.clearOneof(oneof); } @java.lang.Override public Builder setRepeatedField( com.google.protobuf.Descriptors.FieldDescriptor field, int index, java.lang.Object value) { return super.setRepeatedField(field, index, value); } @java.lang.Override public Builder addRepeatedField( com.google.protobuf.Descriptors.FieldDescriptor field, java.lang.Object value) { return super.addRepeatedField(field, value); } @java.lang.Override public Builder mergeFrom(com.google.protobuf.Message other) { if (other instanceof com.google.protobuf.compiler.PluginProtos.Version) { return mergeFrom((com.google.protobuf.compiler.PluginProtos.Version)other); } else { super.mergeFrom(other); return this; } } public Builder mergeFrom(com.google.protobuf.compiler.PluginProtos.Version other) { if (other == com.google.protobuf.compiler.PluginProtos.Version.getDefaultInstance()) return this; if (other.hasMajor()) { setMajor(other.getMajor()); } if (other.hasMinor()) { setMinor(other.getMinor()); } if (other.hasPatch()) { setPatch(other.getPatch()); } if (other.hasSuffix()) { suffix_ = other.suffix_; bitField0_ |= 0x00000008; onChanged(); } this.mergeUnknownFields(other.getUnknownFields()); onChanged(); return this; } @java.lang.Override public final boolean isInitialized() { return true; } @java.lang.Override public Builder mergeFrom( com.google.protobuf.CodedInputStream input, com.google.protobuf.ExtensionRegistryLite extensionRegistry) throws java.io.IOException { if (extensionRegistry == null) { throw new java.lang.NullPointerException(); } try { boolean done = false; while (!done) { int tag = input.readTag(); switch (tag) { case 0: done = true; break; case 8: { major_ = input.readInt32(); bitField0_ |= 0x00000001; break; } // case 8 case 16: { minor_ = input.readInt32(); bitField0_ |= 0x00000002; break; } // case 16 case 24: { patch_ = input.readInt32(); bitField0_ |= 0x00000004; break; } // case 24 case 34: { suffix_ = input.readBytes(); bitField0_ |= 0x00000008; break; } // case 34 default: { if (!super.parseUnknownField(input, extensionRegistry, tag)) { done = true; // was an endgroup tag } break; } // default: } // switch (tag) } // while (!done) } catch (com.google.protobuf.InvalidProtocolBufferException e) { throw e.unwrapIOException(); } finally { onChanged(); } // finally return this; } private int bitField0_; private int major_ ; /** * optional int32 major = 1; * @return Whether the major field is set. */ @java.lang.Override public boolean hasMajor() { return ((bitField0_ & 0x00000001) != 0); } /** * optional int32 major = 1; * @return The major. */ @java.lang.Override public int getMajor() { return major_; } /** * optional int32 major = 1; * @param value The major to set. * @return This builder for chaining. */ public Builder setMajor(int value) { major_ = value; bitField0_ |= 0x00000001; onChanged(); return this; } /** * optional int32 major = 1; * @return This builder for chaining. */ public Builder clearMajor() { bitField0_ = (bitField0_ & ~0x00000001); major_ = 0; onChanged(); return this; } private int minor_ ; /** * optional int32 minor = 2; * @return Whether the minor field is set. */ @java.lang.Override public boolean hasMinor() { return ((bitField0_ & 0x00000002) != 0); } /** * optional int32 minor = 2; * @return The minor. */ @java.lang.Override public int getMinor() { return minor_; } /** * optional int32 minor = 2; * @param value The minor to set. * @return This builder for chaining. */ public Builder setMinor(int value) { minor_ = value; bitField0_ |= 0x00000002; onChanged(); return this; } /** * optional int32 minor = 2; * @return This builder for chaining. */ public Builder clearMinor() { bitField0_ = (bitField0_ & ~0x00000002); minor_ = 0; onChanged(); return this; } private int patch_ ; /** * optional int32 patch = 3; * @return Whether the patch field is set. */ @java.lang.Override public boolean hasPatch() { return ((bitField0_ & 0x00000004) != 0); } /** * optional int32 patch = 3; * @return The patch. */ @java.lang.Override public int getPatch() { return patch_; } /** * optional int32 patch = 3; * @param value The patch to set. * @return This builder for chaining. */ public Builder setPatch(int value) { patch_ = value; bitField0_ |= 0x00000004; onChanged(); return this; } /** * optional int32 patch = 3; * @return This builder for chaining. */ public Builder clearPatch() { bitField0_ = (bitField0_ & ~0x00000004); patch_ = 0; onChanged(); return this; } private java.lang.Object suffix_ = ""; /** *
       * A suffix for alpha, beta or rc release, e.g., "alpha-1", "rc2". It should
       * be empty for mainline stable releases.
       * 
* * optional string suffix = 4; * @return Whether the suffix field is set. */ public boolean hasSuffix() { return ((bitField0_ & 0x00000008) != 0); } /** *
       * A suffix for alpha, beta or rc release, e.g., "alpha-1", "rc2". It should
       * be empty for mainline stable releases.
       * 
* * optional string suffix = 4; * @return The suffix. */ public java.lang.String getSuffix() { java.lang.Object ref = suffix_; if (!(ref instanceof java.lang.String)) { com.google.protobuf.ByteString bs = (com.google.protobuf.ByteString) ref; java.lang.String s = bs.toStringUtf8(); if (bs.isValidUtf8()) { suffix_ = s; } return s; } else { return (java.lang.String) ref; } } /** *
       * A suffix for alpha, beta or rc release, e.g., "alpha-1", "rc2". It should
       * be empty for mainline stable releases.
       * 
* * optional string suffix = 4; * @return The bytes for suffix. */ public com.google.protobuf.ByteString getSuffixBytes() { java.lang.Object ref = suffix_; if (ref instanceof String) { com.google.protobuf.ByteString b = com.google.protobuf.ByteString.copyFromUtf8( (java.lang.String) ref); suffix_ = b; return b; } else { return (com.google.protobuf.ByteString) ref; } } /** *
       * A suffix for alpha, beta or rc release, e.g., "alpha-1", "rc2". It should
       * be empty for mainline stable releases.
       * 
* * optional string suffix = 4; * @param value The suffix to set. * @return This builder for chaining. */ public Builder setSuffix( java.lang.String value) { if (value == null) { throw new NullPointerException(); } suffix_ = value; bitField0_ |= 0x00000008; onChanged(); return this; } /** *
       * A suffix for alpha, beta or rc release, e.g., "alpha-1", "rc2". It should
       * be empty for mainline stable releases.
       * 
* * optional string suffix = 4; * @return This builder for chaining. */ public Builder clearSuffix() { suffix_ = getDefaultInstance().getSuffix(); bitField0_ = (bitField0_ & ~0x00000008); onChanged(); return this; } /** *
       * A suffix for alpha, beta or rc release, e.g., "alpha-1", "rc2". It should
       * be empty for mainline stable releases.
       * 
* * optional string suffix = 4; * @param value The bytes for suffix to set. * @return This builder for chaining. */ public Builder setSuffixBytes( com.google.protobuf.ByteString value) { if (value == null) { throw new NullPointerException(); } suffix_ = value; bitField0_ |= 0x00000008; onChanged(); return this; } @java.lang.Override public final Builder setUnknownFields( final com.google.protobuf.UnknownFieldSet unknownFields) { return super.setUnknownFields(unknownFields); } @java.lang.Override public final Builder mergeUnknownFields( final com.google.protobuf.UnknownFieldSet unknownFields) { return super.mergeUnknownFields(unknownFields); } // @@protoc_insertion_point(builder_scope:google.protobuf.compiler.Version) } // @@protoc_insertion_point(class_scope:google.protobuf.compiler.Version) private static final com.google.protobuf.compiler.PluginProtos.Version DEFAULT_INSTANCE; static { DEFAULT_INSTANCE = new com.google.protobuf.compiler.PluginProtos.Version(); } public static com.google.protobuf.compiler.PluginProtos.Version getDefaultInstance() { return DEFAULT_INSTANCE; } @java.lang.Deprecated public static final com.google.protobuf.Parser PARSER = new com.google.protobuf.AbstractParser() { @java.lang.Override public Version parsePartialFrom( com.google.protobuf.CodedInputStream input, com.google.protobuf.ExtensionRegistryLite extensionRegistry) throws com.google.protobuf.InvalidProtocolBufferException { Builder builder = newBuilder(); try { builder.mergeFrom(input, extensionRegistry); } catch (com.google.protobuf.InvalidProtocolBufferException e) { throw e.setUnfinishedMessage(builder.buildPartial()); } catch (com.google.protobuf.UninitializedMessageException e) { throw e.asInvalidProtocolBufferException().setUnfinishedMessage(builder.buildPartial()); } catch (java.io.IOException e) { throw new com.google.protobuf.InvalidProtocolBufferException(e) .setUnfinishedMessage(builder.buildPartial()); } return builder.buildPartial(); } }; public static com.google.protobuf.Parser parser() { return PARSER; } @java.lang.Override public com.google.protobuf.Parser getParserForType() { return PARSER; } @java.lang.Override public com.google.protobuf.compiler.PluginProtos.Version getDefaultInstanceForType() { return DEFAULT_INSTANCE; } } public interface CodeGeneratorRequestOrBuilder extends // @@protoc_insertion_point(interface_extends:google.protobuf.compiler.CodeGeneratorRequest) com.google.protobuf.MessageOrBuilder { /** *
     * 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.
     * 
* * repeated string file_to_generate = 1; * @return A list containing the fileToGenerate. */ java.util.List getFileToGenerateList(); /** *
     * 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.
     * 
* * repeated string file_to_generate = 1; * @return The count of fileToGenerate. */ int getFileToGenerateCount(); /** *
     * 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.
     * 
* * repeated string file_to_generate = 1; * @param index The index of the element to return. * @return The fileToGenerate at the given index. */ java.lang.String getFileToGenerate(int index); /** *
     * 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.
     * 
* * repeated string file_to_generate = 1; * @param index The index of the value to return. * @return The bytes of the fileToGenerate at the given index. */ com.google.protobuf.ByteString getFileToGenerateBytes(int index); /** *
     * The generator parameter passed on the command-line.
     * 
* * optional string parameter = 2; * @return Whether the parameter field is set. */ boolean hasParameter(); /** *
     * The generator parameter passed on the command-line.
     * 
* * optional string parameter = 2; * @return The parameter. */ java.lang.String getParameter(); /** *
     * The generator parameter passed on the command-line.
     * 
* * optional string parameter = 2; * @return The bytes for parameter. */ com.google.protobuf.ByteString getParameterBytes(); /** *
     * 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.
     * Type names of fields and extensions in the FileDescriptorProto are always
     * fully qualified.
     * 
* * repeated .google.protobuf.FileDescriptorProto proto_file = 15; */ java.util.List getProtoFileList(); /** *
     * 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.
     * Type names of fields and extensions in the FileDescriptorProto are always
     * fully qualified.
     * 
* * repeated .google.protobuf.FileDescriptorProto proto_file = 15; */ com.google.protobuf.DescriptorProtos.FileDescriptorProto getProtoFile(int index); /** *
     * 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.
     * Type names of fields and extensions in the FileDescriptorProto are always
     * fully qualified.
     * 
* * repeated .google.protobuf.FileDescriptorProto proto_file = 15; */ int getProtoFileCount(); /** *
     * 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.
     * Type names of fields and extensions in the FileDescriptorProto are always
     * fully qualified.
     * 
* * repeated .google.protobuf.FileDescriptorProto proto_file = 15; */ java.util.List getProtoFileOrBuilderList(); /** *
     * 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.
     * Type names of fields and extensions in the FileDescriptorProto are always
     * fully qualified.
     * 
* * repeated .google.protobuf.FileDescriptorProto proto_file = 15; */ com.google.protobuf.DescriptorProtos.FileDescriptorProtoOrBuilder getProtoFileOrBuilder( int index); /** *
     * The version number of protocol compiler.
     * 
* * optional .google.protobuf.compiler.Version compiler_version = 3; * @return Whether the compilerVersion field is set. */ boolean hasCompilerVersion(); /** *
     * The version number of protocol compiler.
     * 
* * optional .google.protobuf.compiler.Version compiler_version = 3; * @return The compilerVersion. */ com.google.protobuf.compiler.PluginProtos.Version getCompilerVersion(); /** *
     * The version number of protocol compiler.
     * 
* * optional .google.protobuf.compiler.Version compiler_version = 3; */ com.google.protobuf.compiler.PluginProtos.VersionOrBuilder getCompilerVersionOrBuilder(); } /** *
   * An encoded CodeGeneratorRequest is written to the plugin's stdin.
   * 
* * Protobuf type {@code google.protobuf.compiler.CodeGeneratorRequest} */ public static final class CodeGeneratorRequest extends com.google.protobuf.GeneratedMessageV3 implements // @@protoc_insertion_point(message_implements:google.protobuf.compiler.CodeGeneratorRequest) CodeGeneratorRequestOrBuilder { private static final long serialVersionUID = 0L; // Use CodeGeneratorRequest.newBuilder() to construct. private CodeGeneratorRequest(com.google.protobuf.GeneratedMessageV3.Builder builder) { super(builder); } private CodeGeneratorRequest() { fileToGenerate_ = com.google.protobuf.LazyStringArrayList.EMPTY; parameter_ = ""; protoFile_ = java.util.Collections.emptyList(); } @java.lang.Override @SuppressWarnings({"unused"}) protected java.lang.Object newInstance( UnusedPrivateParameter unused) { return new CodeGeneratorRequest(); } @java.lang.Override public final com.google.protobuf.UnknownFieldSet getUnknownFields() { return this.unknownFields; } public static final com.google.protobuf.Descriptors.Descriptor getDescriptor() { return com.google.protobuf.compiler.PluginProtos.internal_static_google_protobuf_compiler_CodeGeneratorRequest_descriptor; } @java.lang.Override protected com.google.protobuf.GeneratedMessageV3.FieldAccessorTable internalGetFieldAccessorTable() { return com.google.protobuf.compiler.PluginProtos.internal_static_google_protobuf_compiler_CodeGeneratorRequest_fieldAccessorTable .ensureFieldAccessorsInitialized( com.google.protobuf.compiler.PluginProtos.CodeGeneratorRequest.class, com.google.protobuf.compiler.PluginProtos.CodeGeneratorRequest.Builder.class); } private int bitField0_; public static final int FILE_TO_GENERATE_FIELD_NUMBER = 1; @SuppressWarnings("serial") private com.google.protobuf.LazyStringList fileToGenerate_; /** *
     * 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.
     * 
* * repeated string file_to_generate = 1; * @return A list containing the fileToGenerate. */ public com.google.protobuf.ProtocolStringList getFileToGenerateList() { return fileToGenerate_; } /** *
     * 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.
     * 
* * repeated string file_to_generate = 1; * @return The count of fileToGenerate. */ public int getFileToGenerateCount() { return fileToGenerate_.size(); } /** *
     * 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.
     * 
* * repeated string file_to_generate = 1; * @param index The index of the element to return. * @return The fileToGenerate at the given index. */ public java.lang.String getFileToGenerate(int index) { return fileToGenerate_.get(index); } /** *
     * 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.
     * 
* * repeated string file_to_generate = 1; * @param index The index of the value to return. * @return The bytes of the fileToGenerate at the given index. */ public com.google.protobuf.ByteString getFileToGenerateBytes(int index) { return fileToGenerate_.getByteString(index); } public static final int PARAMETER_FIELD_NUMBER = 2; @SuppressWarnings("serial") private volatile java.lang.Object parameter_ = ""; /** *
     * The generator parameter passed on the command-line.
     * 
* * optional string parameter = 2; * @return Whether the parameter field is set. */ @java.lang.Override public boolean hasParameter() { return ((bitField0_ & 0x00000001) != 0); } /** *
     * The generator parameter passed on the command-line.
     * 
* * optional string parameter = 2; * @return The parameter. */ @java.lang.Override public java.lang.String getParameter() { java.lang.Object ref = parameter_; if (ref instanceof java.lang.String) { return (java.lang.String) ref; } else { com.google.protobuf.ByteString bs = (com.google.protobuf.ByteString) ref; java.lang.String s = bs.toStringUtf8(); if (bs.isValidUtf8()) { parameter_ = s; } return s; } } /** *
     * The generator parameter passed on the command-line.
     * 
* * optional string parameter = 2; * @return The bytes for parameter. */ @java.lang.Override public com.google.protobuf.ByteString getParameterBytes() { java.lang.Object ref = parameter_; if (ref instanceof java.lang.String) { com.google.protobuf.ByteString b = com.google.protobuf.ByteString.copyFromUtf8( (java.lang.String) ref); parameter_ = b; return b; } else { return (com.google.protobuf.ByteString) ref; } } public static final int PROTO_FILE_FIELD_NUMBER = 15; @SuppressWarnings("serial") private java.util.List protoFile_; /** *
     * 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.
     * Type names of fields and extensions in the FileDescriptorProto are always
     * fully qualified.
     * 
* * repeated .google.protobuf.FileDescriptorProto proto_file = 15; */ @java.lang.Override public java.util.List getProtoFileList() { return protoFile_; } /** *
     * 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.
     * Type names of fields and extensions in the FileDescriptorProto are always
     * fully qualified.
     * 
* * repeated .google.protobuf.FileDescriptorProto proto_file = 15; */ @java.lang.Override public java.util.List getProtoFileOrBuilderList() { return protoFile_; } /** *
     * 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.
     * Type names of fields and extensions in the FileDescriptorProto are always
     * fully qualified.
     * 
* * repeated .google.protobuf.FileDescriptorProto proto_file = 15; */ @java.lang.Override public int getProtoFileCount() { return protoFile_.size(); } /** *
     * 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.
     * Type names of fields and extensions in the FileDescriptorProto are always
     * fully qualified.
     * 
* * repeated .google.protobuf.FileDescriptorProto proto_file = 15; */ @java.lang.Override public com.google.protobuf.DescriptorProtos.FileDescriptorProto getProtoFile(int index) { return protoFile_.get(index); } /** *
     * 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.
     * Type names of fields and extensions in the FileDescriptorProto are always
     * fully qualified.
     * 
* * repeated .google.protobuf.FileDescriptorProto proto_file = 15; */ @java.lang.Override public com.google.protobuf.DescriptorProtos.FileDescriptorProtoOrBuilder getProtoFileOrBuilder( int index) { return protoFile_.get(index); } public static final int COMPILER_VERSION_FIELD_NUMBER = 3; private com.google.protobuf.compiler.PluginProtos.Version compilerVersion_; /** *
     * The version number of protocol compiler.
     * 
* * optional .google.protobuf.compiler.Version compiler_version = 3; * @return Whether the compilerVersion field is set. */ @java.lang.Override public boolean hasCompilerVersion() { return ((bitField0_ & 0x00000002) != 0); } /** *
     * The version number of protocol compiler.
     * 
* * optional .google.protobuf.compiler.Version compiler_version = 3; * @return The compilerVersion. */ @java.lang.Override public com.google.protobuf.compiler.PluginProtos.Version getCompilerVersion() { return compilerVersion_ == null ? com.google.protobuf.compiler.PluginProtos.Version.getDefaultInstance() : compilerVersion_; } /** *
     * The version number of protocol compiler.
     * 
* * optional .google.protobuf.compiler.Version compiler_version = 3; */ @java.lang.Override public com.google.protobuf.compiler.PluginProtos.VersionOrBuilder getCompilerVersionOrBuilder() { return compilerVersion_ == null ? com.google.protobuf.compiler.PluginProtos.Version.getDefaultInstance() : compilerVersion_; } private byte memoizedIsInitialized = -1; @java.lang.Override public final boolean isInitialized() { byte isInitialized = memoizedIsInitialized; if (isInitialized == 1) return true; if (isInitialized == 0) return false; for (int i = 0; i < getProtoFileCount(); i++) { if (!getProtoFile(i).isInitialized()) { memoizedIsInitialized = 0; return false; } } memoizedIsInitialized = 1; return true; } @java.lang.Override public void writeTo(com.google.protobuf.CodedOutputStream output) throws java.io.IOException { for (int i = 0; i < fileToGenerate_.size(); i++) { com.google.protobuf.GeneratedMessageV3.writeString(output, 1, fileToGenerate_.getRaw(i)); } if (((bitField0_ & 0x00000001) != 0)) { com.google.protobuf.GeneratedMessageV3.writeString(output, 2, parameter_); } if (((bitField0_ & 0x00000002) != 0)) { output.writeMessage(3, getCompilerVersion()); } for (int i = 0; i < protoFile_.size(); i++) { output.writeMessage(15, protoFile_.get(i)); } getUnknownFields().writeTo(output); } @java.lang.Override public int getSerializedSize() { int size = memoizedSize; if (size != -1) return size; size = 0; { int dataSize = 0; for (int i = 0; i < fileToGenerate_.size(); i++) { dataSize += computeStringSizeNoTag(fileToGenerate_.getRaw(i)); } size += dataSize; size += 1 * getFileToGenerateList().size(); } if (((bitField0_ & 0x00000001) != 0)) { size += com.google.protobuf.GeneratedMessageV3.computeStringSize(2, parameter_); } if (((bitField0_ & 0x00000002) != 0)) { size += com.google.protobuf.CodedOutputStream .computeMessageSize(3, getCompilerVersion()); } for (int i = 0; i < protoFile_.size(); i++) { size += com.google.protobuf.CodedOutputStream .computeMessageSize(15, protoFile_.get(i)); } size += getUnknownFields().getSerializedSize(); memoizedSize = size; return size; } @java.lang.Override public boolean equals(final java.lang.Object obj) { if (obj == this) { return true; } if (!(obj instanceof com.google.protobuf.compiler.PluginProtos.CodeGeneratorRequest)) { return super.equals(obj); } com.google.protobuf.compiler.PluginProtos.CodeGeneratorRequest other = (com.google.protobuf.compiler.PluginProtos.CodeGeneratorRequest) obj; if (!getFileToGenerateList() .equals(other.getFileToGenerateList())) return false; if (hasParameter() != other.hasParameter()) return false; if (hasParameter()) { if (!getParameter() .equals(other.getParameter())) return false; } if (!getProtoFileList() .equals(other.getProtoFileList())) return false; if (hasCompilerVersion() != other.hasCompilerVersion()) return false; if (hasCompilerVersion()) { if (!getCompilerVersion() .equals(other.getCompilerVersion())) return false; } if (!getUnknownFields().equals(other.getUnknownFields())) return false; return true; } @java.lang.Override public int hashCode() { if (memoizedHashCode != 0) { return memoizedHashCode; } int hash = 41; hash = (19 * hash) + getDescriptor().hashCode(); if (getFileToGenerateCount() > 0) { hash = (37 * hash) + FILE_TO_GENERATE_FIELD_NUMBER; hash = (53 * hash) + getFileToGenerateList().hashCode(); } if (hasParameter()) { hash = (37 * hash) + PARAMETER_FIELD_NUMBER; hash = (53 * hash) + getParameter().hashCode(); } if (getProtoFileCount() > 0) { hash = (37 * hash) + PROTO_FILE_FIELD_NUMBER; hash = (53 * hash) + getProtoFileList().hashCode(); } if (hasCompilerVersion()) { hash = (37 * hash) + COMPILER_VERSION_FIELD_NUMBER; hash = (53 * hash) + getCompilerVersion().hashCode(); } hash = (29 * hash) + getUnknownFields().hashCode(); memoizedHashCode = hash; return hash; } public static com.google.protobuf.compiler.PluginProtos.CodeGeneratorRequest parseFrom( java.nio.ByteBuffer data) throws com.google.protobuf.InvalidProtocolBufferException { return PARSER.parseFrom(data); } public static com.google.protobuf.compiler.PluginProtos.CodeGeneratorRequest parseFrom( java.nio.ByteBuffer data, com.google.protobuf.ExtensionRegistryLite extensionRegistry) throws com.google.protobuf.InvalidProtocolBufferException { return PARSER.parseFrom(data, extensionRegistry); } public static com.google.protobuf.compiler.PluginProtos.CodeGeneratorRequest parseFrom( com.google.protobuf.ByteString data) throws com.google.protobuf.InvalidProtocolBufferException { return PARSER.parseFrom(data); } public static com.google.protobuf.compiler.PluginProtos.CodeGeneratorRequest parseFrom( com.google.protobuf.ByteString data, com.google.protobuf.ExtensionRegistryLite extensionRegistry) throws com.google.protobuf.InvalidProtocolBufferException { return PARSER.parseFrom(data, extensionRegistry); } public static com.google.protobuf.compiler.PluginProtos.CodeGeneratorRequest parseFrom(byte[] data) throws com.google.protobuf.InvalidProtocolBufferException { return PARSER.parseFrom(data); } public static com.google.protobuf.compiler.PluginProtos.CodeGeneratorRequest parseFrom( byte[] data, com.google.protobuf.ExtensionRegistryLite extensionRegistry) throws com.google.protobuf.InvalidProtocolBufferException { return PARSER.parseFrom(data, extensionRegistry); } public static com.google.protobuf.compiler.PluginProtos.CodeGeneratorRequest parseFrom(java.io.InputStream input) throws java.io.IOException { return com.google.protobuf.GeneratedMessageV3 .parseWithIOException(PARSER, input); } public static com.google.protobuf.compiler.PluginProtos.CodeGeneratorRequest parseFrom( java.io.InputStream input, com.google.protobuf.ExtensionRegistryLite extensionRegistry) throws java.io.IOException { return com.google.protobuf.GeneratedMessageV3 .parseWithIOException(PARSER, input, extensionRegistry); } public static com.google.protobuf.compiler.PluginProtos.CodeGeneratorRequest parseDelimitedFrom(java.io.InputStream input) throws java.io.IOException { return com.google.protobuf.GeneratedMessageV3 .parseDelimitedWithIOException(PARSER, input); } public static com.google.protobuf.compiler.PluginProtos.CodeGeneratorRequest parseDelimitedFrom( java.io.InputStream input, com.google.protobuf.ExtensionRegistryLite extensionRegistry) throws java.io.IOException { return com.google.protobuf.GeneratedMessageV3 .parseDelimitedWithIOException(PARSER, input, extensionRegistry); } public static com.google.protobuf.compiler.PluginProtos.CodeGeneratorRequest parseFrom( com.google.protobuf.CodedInputStream input) throws java.io.IOException { return com.google.protobuf.GeneratedMessageV3 .parseWithIOException(PARSER, input); } public static com.google.protobuf.compiler.PluginProtos.CodeGeneratorRequest parseFrom( com.google.protobuf.CodedInputStream input, com.google.protobuf.ExtensionRegistryLite extensionRegistry) throws java.io.IOException { return com.google.protobuf.GeneratedMessageV3 .parseWithIOException(PARSER, input, extensionRegistry); } @java.lang.Override public Builder newBuilderForType() { return newBuilder(); } public static Builder newBuilder() { return DEFAULT_INSTANCE.toBuilder(); } public static Builder newBuilder(com.google.protobuf.compiler.PluginProtos.CodeGeneratorRequest prototype) { return DEFAULT_INSTANCE.toBuilder().mergeFrom(prototype); } @java.lang.Override public Builder toBuilder() { return this == DEFAULT_INSTANCE ? new Builder() : new Builder().mergeFrom(this); } @java.lang.Override protected Builder newBuilderForType( com.google.protobuf.GeneratedMessageV3.BuilderParent parent) { Builder builder = new Builder(parent); return builder; } /** *
     * An encoded CodeGeneratorRequest is written to the plugin's stdin.
     * 
* * Protobuf type {@code google.protobuf.compiler.CodeGeneratorRequest} */ public static final class Builder extends com.google.protobuf.GeneratedMessageV3.Builder implements // @@protoc_insertion_point(builder_implements:google.protobuf.compiler.CodeGeneratorRequest) com.google.protobuf.compiler.PluginProtos.CodeGeneratorRequestOrBuilder { public static final com.google.protobuf.Descriptors.Descriptor getDescriptor() { return com.google.protobuf.compiler.PluginProtos.internal_static_google_protobuf_compiler_CodeGeneratorRequest_descriptor; } @java.lang.Override protected com.google.protobuf.GeneratedMessageV3.FieldAccessorTable internalGetFieldAccessorTable() { return com.google.protobuf.compiler.PluginProtos.internal_static_google_protobuf_compiler_CodeGeneratorRequest_fieldAccessorTable .ensureFieldAccessorsInitialized( com.google.protobuf.compiler.PluginProtos.CodeGeneratorRequest.class, com.google.protobuf.compiler.PluginProtos.CodeGeneratorRequest.Builder.class); } // Construct using com.google.protobuf.compiler.PluginProtos.CodeGeneratorRequest.newBuilder() private Builder() { maybeForceBuilderInitialization(); } private Builder( com.google.protobuf.GeneratedMessageV3.BuilderParent parent) { super(parent); maybeForceBuilderInitialization(); } private void maybeForceBuilderInitialization() { if (com.google.protobuf.GeneratedMessageV3 .alwaysUseFieldBuilders) { getProtoFileFieldBuilder(); getCompilerVersionFieldBuilder(); } } @java.lang.Override public Builder clear() { super.clear(); bitField0_ = 0; fileToGenerate_ = com.google.protobuf.LazyStringArrayList.EMPTY; bitField0_ = (bitField0_ & ~0x00000001); parameter_ = ""; if (protoFileBuilder_ == null) { protoFile_ = java.util.Collections.emptyList(); } else { protoFile_ = null; protoFileBuilder_.clear(); } bitField0_ = (bitField0_ & ~0x00000004); compilerVersion_ = null; if (compilerVersionBuilder_ != null) { compilerVersionBuilder_.dispose(); compilerVersionBuilder_ = null; } return this; } @java.lang.Override public com.google.protobuf.Descriptors.Descriptor getDescriptorForType() { return com.google.protobuf.compiler.PluginProtos.internal_static_google_protobuf_compiler_CodeGeneratorRequest_descriptor; } @java.lang.Override public com.google.protobuf.compiler.PluginProtos.CodeGeneratorRequest getDefaultInstanceForType() { return com.google.protobuf.compiler.PluginProtos.CodeGeneratorRequest.getDefaultInstance(); } @java.lang.Override public com.google.protobuf.compiler.PluginProtos.CodeGeneratorRequest build() { com.google.protobuf.compiler.PluginProtos.CodeGeneratorRequest result = buildPartial(); if (!result.isInitialized()) { throw newUninitializedMessageException(result); } return result; } @java.lang.Override public com.google.protobuf.compiler.PluginProtos.CodeGeneratorRequest buildPartial() { com.google.protobuf.compiler.PluginProtos.CodeGeneratorRequest result = new com.google.protobuf.compiler.PluginProtos.CodeGeneratorRequest(this); buildPartialRepeatedFields(result); if (bitField0_ != 0) { buildPartial0(result); } onBuilt(); return result; } private void buildPartialRepeatedFields(com.google.protobuf.compiler.PluginProtos.CodeGeneratorRequest result) { if (((bitField0_ & 0x00000001) != 0)) { fileToGenerate_ = fileToGenerate_.getUnmodifiableView(); bitField0_ = (bitField0_ & ~0x00000001); } result.fileToGenerate_ = fileToGenerate_; if (protoFileBuilder_ == null) { if (((bitField0_ & 0x00000004) != 0)) { protoFile_ = java.util.Collections.unmodifiableList(protoFile_); bitField0_ = (bitField0_ & ~0x00000004); } result.protoFile_ = protoFile_; } else { result.protoFile_ = protoFileBuilder_.build(); } } private void buildPartial0(com.google.protobuf.compiler.PluginProtos.CodeGeneratorRequest result) { int from_bitField0_ = bitField0_; int to_bitField0_ = 0; if (((from_bitField0_ & 0x00000002) != 0)) { result.parameter_ = parameter_; to_bitField0_ |= 0x00000001; } if (((from_bitField0_ & 0x00000008) != 0)) { result.compilerVersion_ = compilerVersionBuilder_ == null ? compilerVersion_ : compilerVersionBuilder_.build(); to_bitField0_ |= 0x00000002; } result.bitField0_ |= to_bitField0_; } @java.lang.Override public Builder clone() { return super.clone(); } @java.lang.Override public Builder setField( com.google.protobuf.Descriptors.FieldDescriptor field, java.lang.Object value) { return super.setField(field, value); } @java.lang.Override public Builder clearField( com.google.protobuf.Descriptors.FieldDescriptor field) { return super.clearField(field); } @java.lang.Override public Builder clearOneof( com.google.protobuf.Descriptors.OneofDescriptor oneof) { return super.clearOneof(oneof); } @java.lang.Override public Builder setRepeatedField( com.google.protobuf.Descriptors.FieldDescriptor field, int index, java.lang.Object value) { return super.setRepeatedField(field, index, value); } @java.lang.Override public Builder addRepeatedField( com.google.protobuf.Descriptors.FieldDescriptor field, java.lang.Object value) { return super.addRepeatedField(field, value); } @java.lang.Override public Builder mergeFrom(com.google.protobuf.Message other) { if (other instanceof com.google.protobuf.compiler.PluginProtos.CodeGeneratorRequest) { return mergeFrom((com.google.protobuf.compiler.PluginProtos.CodeGeneratorRequest)other); } else { super.mergeFrom(other); return this; } } public Builder mergeFrom(com.google.protobuf.compiler.PluginProtos.CodeGeneratorRequest other) { if (other == com.google.protobuf.compiler.PluginProtos.CodeGeneratorRequest.getDefaultInstance()) return this; if (!other.fileToGenerate_.isEmpty()) { if (fileToGenerate_.isEmpty()) { fileToGenerate_ = other.fileToGenerate_; bitField0_ = (bitField0_ & ~0x00000001); } else { ensureFileToGenerateIsMutable(); fileToGenerate_.addAll(other.fileToGenerate_); } onChanged(); } if (other.hasParameter()) { parameter_ = other.parameter_; bitField0_ |= 0x00000002; onChanged(); } if (protoFileBuilder_ == null) { if (!other.protoFile_.isEmpty()) { if (protoFile_.isEmpty()) { protoFile_ = other.protoFile_; bitField0_ = (bitField0_ & ~0x00000004); } else { ensureProtoFileIsMutable(); protoFile_.addAll(other.protoFile_); } onChanged(); } } else { if (!other.protoFile_.isEmpty()) { if (protoFileBuilder_.isEmpty()) { protoFileBuilder_.dispose(); protoFileBuilder_ = null; protoFile_ = other.protoFile_; bitField0_ = (bitField0_ & ~0x00000004); protoFileBuilder_ = com.google.protobuf.GeneratedMessageV3.alwaysUseFieldBuilders ? getProtoFileFieldBuilder() : null; } else { protoFileBuilder_.addAllMessages(other.protoFile_); } } } if (other.hasCompilerVersion()) { mergeCompilerVersion(other.getCompilerVersion()); } this.mergeUnknownFields(other.getUnknownFields()); onChanged(); return this; } @java.lang.Override public final boolean isInitialized() { for (int i = 0; i < getProtoFileCount(); i++) { if (!getProtoFile(i).isInitialized()) { return false; } } return true; } @java.lang.Override public Builder mergeFrom( com.google.protobuf.CodedInputStream input, com.google.protobuf.ExtensionRegistryLite extensionRegistry) throws java.io.IOException { if (extensionRegistry == null) { throw new java.lang.NullPointerException(); } try { boolean done = false; while (!done) { int tag = input.readTag(); switch (tag) { case 0: done = true; break; case 10: { com.google.protobuf.ByteString bs = input.readBytes(); ensureFileToGenerateIsMutable(); fileToGenerate_.add(bs); break; } // case 10 case 18: { parameter_ = input.readBytes(); bitField0_ |= 0x00000002; break; } // case 18 case 26: { input.readMessage( getCompilerVersionFieldBuilder().getBuilder(), extensionRegistry); bitField0_ |= 0x00000008; break; } // case 26 case 122: { com.google.protobuf.DescriptorProtos.FileDescriptorProto m = input.readMessage( com.google.protobuf.DescriptorProtos.FileDescriptorProto.PARSER, extensionRegistry); if (protoFileBuilder_ == null) { ensureProtoFileIsMutable(); protoFile_.add(m); } else { protoFileBuilder_.addMessage(m); } break; } // case 122 default: { if (!super.parseUnknownField(input, extensionRegistry, tag)) { done = true; // was an endgroup tag } break; } // default: } // switch (tag) } // while (!done) } catch (com.google.protobuf.InvalidProtocolBufferException e) { throw e.unwrapIOException(); } finally { onChanged(); } // finally return this; } private int bitField0_; private com.google.protobuf.LazyStringList fileToGenerate_ = com.google.protobuf.LazyStringArrayList.EMPTY; private void ensureFileToGenerateIsMutable() { if (!((bitField0_ & 0x00000001) != 0)) { fileToGenerate_ = new com.google.protobuf.LazyStringArrayList(fileToGenerate_); bitField0_ |= 0x00000001; } } /** *
       * 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.
       * 
* * repeated string file_to_generate = 1; * @return A list containing the fileToGenerate. */ public com.google.protobuf.ProtocolStringList getFileToGenerateList() { return fileToGenerate_.getUnmodifiableView(); } /** *
       * 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.
       * 
* * repeated string file_to_generate = 1; * @return The count of fileToGenerate. */ public int getFileToGenerateCount() { return fileToGenerate_.size(); } /** *
       * 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.
       * 
* * repeated string file_to_generate = 1; * @param index The index of the element to return. * @return The fileToGenerate at the given index. */ public java.lang.String getFileToGenerate(int index) { return fileToGenerate_.get(index); } /** *
       * 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.
       * 
* * repeated string file_to_generate = 1; * @param index The index of the value to return. * @return The bytes of the fileToGenerate at the given index. */ public com.google.protobuf.ByteString getFileToGenerateBytes(int index) { return fileToGenerate_.getByteString(index); } /** *
       * 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.
       * 
* * repeated string file_to_generate = 1; * @param index The index to set the value at. * @param value The fileToGenerate to set. * @return This builder for chaining. */ public Builder setFileToGenerate( int index, java.lang.String value) { if (value == null) { throw new NullPointerException(); } ensureFileToGenerateIsMutable(); fileToGenerate_.set(index, value); onChanged(); return this; } /** *
       * 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.
       * 
* * repeated string file_to_generate = 1; * @param value The fileToGenerate to add. * @return This builder for chaining. */ public Builder addFileToGenerate( java.lang.String value) { if (value == null) { throw new NullPointerException(); } ensureFileToGenerateIsMutable(); fileToGenerate_.add(value); onChanged(); return this; } /** *
       * 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.
       * 
* * repeated string file_to_generate = 1; * @param values The fileToGenerate to add. * @return This builder for chaining. */ public Builder addAllFileToGenerate( java.lang.Iterable values) { ensureFileToGenerateIsMutable(); com.google.protobuf.AbstractMessageLite.Builder.addAll( values, fileToGenerate_); onChanged(); return this; } /** *
       * 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.
       * 
* * repeated string file_to_generate = 1; * @return This builder for chaining. */ public Builder clearFileToGenerate() { fileToGenerate_ = com.google.protobuf.LazyStringArrayList.EMPTY; bitField0_ = (bitField0_ & ~0x00000001); onChanged(); return this; } /** *
       * 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.
       * 
* * repeated string file_to_generate = 1; * @param value The bytes of the fileToGenerate to add. * @return This builder for chaining. */ public Builder addFileToGenerateBytes( com.google.protobuf.ByteString value) { if (value == null) { throw new NullPointerException(); } ensureFileToGenerateIsMutable(); fileToGenerate_.add(value); onChanged(); return this; } private java.lang.Object parameter_ = ""; /** *
       * The generator parameter passed on the command-line.
       * 
* * optional string parameter = 2; * @return Whether the parameter field is set. */ public boolean hasParameter() { return ((bitField0_ & 0x00000002) != 0); } /** *
       * The generator parameter passed on the command-line.
       * 
* * optional string parameter = 2; * @return The parameter. */ public java.lang.String getParameter() { java.lang.Object ref = parameter_; if (!(ref instanceof java.lang.String)) { com.google.protobuf.ByteString bs = (com.google.protobuf.ByteString) ref; java.lang.String s = bs.toStringUtf8(); if (bs.isValidUtf8()) { parameter_ = s; } return s; } else { return (java.lang.String) ref; } } /** *
       * The generator parameter passed on the command-line.
       * 
* * optional string parameter = 2; * @return The bytes for parameter. */ public com.google.protobuf.ByteString getParameterBytes() { java.lang.Object ref = parameter_; if (ref instanceof String) { com.google.protobuf.ByteString b = com.google.protobuf.ByteString.copyFromUtf8( (java.lang.String) ref); parameter_ = b; return b; } else { return (com.google.protobuf.ByteString) ref; } } /** *
       * The generator parameter passed on the command-line.
       * 
* * optional string parameter = 2; * @param value The parameter to set. * @return This builder for chaining. */ public Builder setParameter( java.lang.String value) { if (value == null) { throw new NullPointerException(); } parameter_ = value; bitField0_ |= 0x00000002; onChanged(); return this; } /** *
       * The generator parameter passed on the command-line.
       * 
* * optional string parameter = 2; * @return This builder for chaining. */ public Builder clearParameter() { parameter_ = getDefaultInstance().getParameter(); bitField0_ = (bitField0_ & ~0x00000002); onChanged(); return this; } /** *
       * The generator parameter passed on the command-line.
       * 
* * optional string parameter = 2; * @param value The bytes for parameter to set. * @return This builder for chaining. */ public Builder setParameterBytes( com.google.protobuf.ByteString value) { if (value == null) { throw new NullPointerException(); } parameter_ = value; bitField0_ |= 0x00000002; onChanged(); return this; } private java.util.List protoFile_ = java.util.Collections.emptyList(); private void ensureProtoFileIsMutable() { if (!((bitField0_ & 0x00000004) != 0)) { protoFile_ = new java.util.ArrayList(protoFile_); bitField0_ |= 0x00000004; } } private com.google.protobuf.RepeatedFieldBuilderV3< com.google.protobuf.DescriptorProtos.FileDescriptorProto, com.google.protobuf.DescriptorProtos.FileDescriptorProto.Builder, com.google.protobuf.DescriptorProtos.FileDescriptorProtoOrBuilder> protoFileBuilder_; /** *
       * 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.
       * Type names of fields and extensions in the FileDescriptorProto are always
       * fully qualified.
       * 
* * repeated .google.protobuf.FileDescriptorProto proto_file = 15; */ public java.util.List getProtoFileList() { if (protoFileBuilder_ == null) { return java.util.Collections.unmodifiableList(protoFile_); } else { return protoFileBuilder_.getMessageList(); } } /** *
       * 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.
       * Type names of fields and extensions in the FileDescriptorProto are always
       * fully qualified.
       * 
* * repeated .google.protobuf.FileDescriptorProto proto_file = 15; */ public int getProtoFileCount() { if (protoFileBuilder_ == null) { return protoFile_.size(); } else { return protoFileBuilder_.getCount(); } } /** *
       * 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.
       * Type names of fields and extensions in the FileDescriptorProto are always
       * fully qualified.
       * 
* * repeated .google.protobuf.FileDescriptorProto proto_file = 15; */ public com.google.protobuf.DescriptorProtos.FileDescriptorProto getProtoFile(int index) { if (protoFileBuilder_ == null) { return protoFile_.get(index); } else { return protoFileBuilder_.getMessage(index); } } /** *
       * 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.
       * Type names of fields and extensions in the FileDescriptorProto are always
       * fully qualified.
       * 
* * repeated .google.protobuf.FileDescriptorProto proto_file = 15; */ public Builder setProtoFile( int index, com.google.protobuf.DescriptorProtos.FileDescriptorProto value) { if (protoFileBuilder_ == null) { if (value == null) { throw new NullPointerException(); } ensureProtoFileIsMutable(); protoFile_.set(index, value); onChanged(); } else { protoFileBuilder_.setMessage(index, value); } return this; } /** *
       * 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.
       * Type names of fields and extensions in the FileDescriptorProto are always
       * fully qualified.
       * 
* * repeated .google.protobuf.FileDescriptorProto proto_file = 15; */ public Builder setProtoFile( int index, com.google.protobuf.DescriptorProtos.FileDescriptorProto.Builder builderForValue) { if (protoFileBuilder_ == null) { ensureProtoFileIsMutable(); protoFile_.set(index, builderForValue.build()); onChanged(); } else { protoFileBuilder_.setMessage(index, builderForValue.build()); } return this; } /** *
       * 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.
       * Type names of fields and extensions in the FileDescriptorProto are always
       * fully qualified.
       * 
* * repeated .google.protobuf.FileDescriptorProto proto_file = 15; */ public Builder addProtoFile(com.google.protobuf.DescriptorProtos.FileDescriptorProto value) { if (protoFileBuilder_ == null) { if (value == null) { throw new NullPointerException(); } ensureProtoFileIsMutable(); protoFile_.add(value); onChanged(); } else { protoFileBuilder_.addMessage(value); } return this; } /** *
       * 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.
       * Type names of fields and extensions in the FileDescriptorProto are always
       * fully qualified.
       * 
* * repeated .google.protobuf.FileDescriptorProto proto_file = 15; */ public Builder addProtoFile( int index, com.google.protobuf.DescriptorProtos.FileDescriptorProto value) { if (protoFileBuilder_ == null) { if (value == null) { throw new NullPointerException(); } ensureProtoFileIsMutable(); protoFile_.add(index, value); onChanged(); } else { protoFileBuilder_.addMessage(index, value); } return this; } /** *
       * 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.
       * Type names of fields and extensions in the FileDescriptorProto are always
       * fully qualified.
       * 
* * repeated .google.protobuf.FileDescriptorProto proto_file = 15; */ public Builder addProtoFile( com.google.protobuf.DescriptorProtos.FileDescriptorProto.Builder builderForValue) { if (protoFileBuilder_ == null) { ensureProtoFileIsMutable(); protoFile_.add(builderForValue.build()); onChanged(); } else { protoFileBuilder_.addMessage(builderForValue.build()); } return this; } /** *
       * 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.
       * Type names of fields and extensions in the FileDescriptorProto are always
       * fully qualified.
       * 
* * repeated .google.protobuf.FileDescriptorProto proto_file = 15; */ public Builder addProtoFile( int index, com.google.protobuf.DescriptorProtos.FileDescriptorProto.Builder builderForValue) { if (protoFileBuilder_ == null) { ensureProtoFileIsMutable(); protoFile_.add(index, builderForValue.build()); onChanged(); } else { protoFileBuilder_.addMessage(index, builderForValue.build()); } return this; } /** *
       * 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.
       * Type names of fields and extensions in the FileDescriptorProto are always
       * fully qualified.
       * 
* * repeated .google.protobuf.FileDescriptorProto proto_file = 15; */ public Builder addAllProtoFile( java.lang.Iterable values) { if (protoFileBuilder_ == null) { ensureProtoFileIsMutable(); com.google.protobuf.AbstractMessageLite.Builder.addAll( values, protoFile_); onChanged(); } else { protoFileBuilder_.addAllMessages(values); } return this; } /** *
       * 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.
       * Type names of fields and extensions in the FileDescriptorProto are always
       * fully qualified.
       * 
* * repeated .google.protobuf.FileDescriptorProto proto_file = 15; */ public Builder clearProtoFile() { if (protoFileBuilder_ == null) { protoFile_ = java.util.Collections.emptyList(); bitField0_ = (bitField0_ & ~0x00000004); onChanged(); } else { protoFileBuilder_.clear(); } return this; } /** *
       * 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.
       * Type names of fields and extensions in the FileDescriptorProto are always
       * fully qualified.
       * 
* * repeated .google.protobuf.FileDescriptorProto proto_file = 15; */ public Builder removeProtoFile(int index) { if (protoFileBuilder_ == null) { ensureProtoFileIsMutable(); protoFile_.remove(index); onChanged(); } else { protoFileBuilder_.remove(index); } return this; } /** *
       * 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.
       * Type names of fields and extensions in the FileDescriptorProto are always
       * fully qualified.
       * 
* * repeated .google.protobuf.FileDescriptorProto proto_file = 15; */ public com.google.protobuf.DescriptorProtos.FileDescriptorProto.Builder getProtoFileBuilder( int index) { return getProtoFileFieldBuilder().getBuilder(index); } /** *
       * 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.
       * Type names of fields and extensions in the FileDescriptorProto are always
       * fully qualified.
       * 
* * repeated .google.protobuf.FileDescriptorProto proto_file = 15; */ public com.google.protobuf.DescriptorProtos.FileDescriptorProtoOrBuilder getProtoFileOrBuilder( int index) { if (protoFileBuilder_ == null) { return protoFile_.get(index); } else { return protoFileBuilder_.getMessageOrBuilder(index); } } /** *
       * 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.
       * Type names of fields and extensions in the FileDescriptorProto are always
       * fully qualified.
       * 
* * repeated .google.protobuf.FileDescriptorProto proto_file = 15; */ public java.util.List getProtoFileOrBuilderList() { if (protoFileBuilder_ != null) { return protoFileBuilder_.getMessageOrBuilderList(); } else { return java.util.Collections.unmodifiableList(protoFile_); } } /** *
       * 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.
       * Type names of fields and extensions in the FileDescriptorProto are always
       * fully qualified.
       * 
* * repeated .google.protobuf.FileDescriptorProto proto_file = 15; */ public com.google.protobuf.DescriptorProtos.FileDescriptorProto.Builder addProtoFileBuilder() { return getProtoFileFieldBuilder().addBuilder( com.google.protobuf.DescriptorProtos.FileDescriptorProto.getDefaultInstance()); } /** *
       * 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.
       * Type names of fields and extensions in the FileDescriptorProto are always
       * fully qualified.
       * 
* * repeated .google.protobuf.FileDescriptorProto proto_file = 15; */ public com.google.protobuf.DescriptorProtos.FileDescriptorProto.Builder addProtoFileBuilder( int index) { return getProtoFileFieldBuilder().addBuilder( index, com.google.protobuf.DescriptorProtos.FileDescriptorProto.getDefaultInstance()); } /** *
       * 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.
       * Type names of fields and extensions in the FileDescriptorProto are always
       * fully qualified.
       * 
* * repeated .google.protobuf.FileDescriptorProto proto_file = 15; */ public java.util.List getProtoFileBuilderList() { return getProtoFileFieldBuilder().getBuilderList(); } private com.google.protobuf.RepeatedFieldBuilderV3< com.google.protobuf.DescriptorProtos.FileDescriptorProto, com.google.protobuf.DescriptorProtos.FileDescriptorProto.Builder, com.google.protobuf.DescriptorProtos.FileDescriptorProtoOrBuilder> getProtoFileFieldBuilder() { if (protoFileBuilder_ == null) { protoFileBuilder_ = new com.google.protobuf.RepeatedFieldBuilderV3< com.google.protobuf.DescriptorProtos.FileDescriptorProto, com.google.protobuf.DescriptorProtos.FileDescriptorProto.Builder, com.google.protobuf.DescriptorProtos.FileDescriptorProtoOrBuilder>( protoFile_, ((bitField0_ & 0x00000004) != 0), getParentForChildren(), isClean()); protoFile_ = null; } return protoFileBuilder_; } private com.google.protobuf.compiler.PluginProtos.Version compilerVersion_; private com.google.protobuf.SingleFieldBuilderV3< com.google.protobuf.compiler.PluginProtos.Version, com.google.protobuf.compiler.PluginProtos.Version.Builder, com.google.protobuf.compiler.PluginProtos.VersionOrBuilder> compilerVersionBuilder_; /** *
       * The version number of protocol compiler.
       * 
* * optional .google.protobuf.compiler.Version compiler_version = 3; * @return Whether the compilerVersion field is set. */ public boolean hasCompilerVersion() { return ((bitField0_ & 0x00000008) != 0); } /** *
       * The version number of protocol compiler.
       * 
* * optional .google.protobuf.compiler.Version compiler_version = 3; * @return The compilerVersion. */ public com.google.protobuf.compiler.PluginProtos.Version getCompilerVersion() { if (compilerVersionBuilder_ == null) { return compilerVersion_ == null ? com.google.protobuf.compiler.PluginProtos.Version.getDefaultInstance() : compilerVersion_; } else { return compilerVersionBuilder_.getMessage(); } } /** *
       * The version number of protocol compiler.
       * 
* * optional .google.protobuf.compiler.Version compiler_version = 3; */ public Builder setCompilerVersion(com.google.protobuf.compiler.PluginProtos.Version value) { if (compilerVersionBuilder_ == null) { if (value == null) { throw new NullPointerException(); } compilerVersion_ = value; } else { compilerVersionBuilder_.setMessage(value); } bitField0_ |= 0x00000008; onChanged(); return this; } /** *
       * The version number of protocol compiler.
       * 
* * optional .google.protobuf.compiler.Version compiler_version = 3; */ public Builder setCompilerVersion( com.google.protobuf.compiler.PluginProtos.Version.Builder builderForValue) { if (compilerVersionBuilder_ == null) { compilerVersion_ = builderForValue.build(); } else { compilerVersionBuilder_.setMessage(builderForValue.build()); } bitField0_ |= 0x00000008; onChanged(); return this; } /** *
       * The version number of protocol compiler.
       * 
* * optional .google.protobuf.compiler.Version compiler_version = 3; */ public Builder mergeCompilerVersion(com.google.protobuf.compiler.PluginProtos.Version value) { if (compilerVersionBuilder_ == null) { if (((bitField0_ & 0x00000008) != 0) && compilerVersion_ != null && compilerVersion_ != com.google.protobuf.compiler.PluginProtos.Version.getDefaultInstance()) { getCompilerVersionBuilder().mergeFrom(value); } else { compilerVersion_ = value; } } else { compilerVersionBuilder_.mergeFrom(value); } bitField0_ |= 0x00000008; onChanged(); return this; } /** *
       * The version number of protocol compiler.
       * 
* * optional .google.protobuf.compiler.Version compiler_version = 3; */ public Builder clearCompilerVersion() { bitField0_ = (bitField0_ & ~0x00000008); compilerVersion_ = null; if (compilerVersionBuilder_ != null) { compilerVersionBuilder_.dispose(); compilerVersionBuilder_ = null; } onChanged(); return this; } /** *
       * The version number of protocol compiler.
       * 
* * optional .google.protobuf.compiler.Version compiler_version = 3; */ public com.google.protobuf.compiler.PluginProtos.Version.Builder getCompilerVersionBuilder() { bitField0_ |= 0x00000008; onChanged(); return getCompilerVersionFieldBuilder().getBuilder(); } /** *
       * The version number of protocol compiler.
       * 
* * optional .google.protobuf.compiler.Version compiler_version = 3; */ public com.google.protobuf.compiler.PluginProtos.VersionOrBuilder getCompilerVersionOrBuilder() { if (compilerVersionBuilder_ != null) { return compilerVersionBuilder_.getMessageOrBuilder(); } else { return compilerVersion_ == null ? com.google.protobuf.compiler.PluginProtos.Version.getDefaultInstance() : compilerVersion_; } } /** *
       * The version number of protocol compiler.
       * 
* * optional .google.protobuf.compiler.Version compiler_version = 3; */ private com.google.protobuf.SingleFieldBuilderV3< com.google.protobuf.compiler.PluginProtos.Version, com.google.protobuf.compiler.PluginProtos.Version.Builder, com.google.protobuf.compiler.PluginProtos.VersionOrBuilder> getCompilerVersionFieldBuilder() { if (compilerVersionBuilder_ == null) { compilerVersionBuilder_ = new com.google.protobuf.SingleFieldBuilderV3< com.google.protobuf.compiler.PluginProtos.Version, com.google.protobuf.compiler.PluginProtos.Version.Builder, com.google.protobuf.compiler.PluginProtos.VersionOrBuilder>( getCompilerVersion(), getParentForChildren(), isClean()); compilerVersion_ = null; } return compilerVersionBuilder_; } @java.lang.Override public final Builder setUnknownFields( final com.google.protobuf.UnknownFieldSet unknownFields) { return super.setUnknownFields(unknownFields); } @java.lang.Override public final Builder mergeUnknownFields( final com.google.protobuf.UnknownFieldSet unknownFields) { return super.mergeUnknownFields(unknownFields); } // @@protoc_insertion_point(builder_scope:google.protobuf.compiler.CodeGeneratorRequest) } // @@protoc_insertion_point(class_scope:google.protobuf.compiler.CodeGeneratorRequest) private static final com.google.protobuf.compiler.PluginProtos.CodeGeneratorRequest DEFAULT_INSTANCE; static { DEFAULT_INSTANCE = new com.google.protobuf.compiler.PluginProtos.CodeGeneratorRequest(); } public static com.google.protobuf.compiler.PluginProtos.CodeGeneratorRequest getDefaultInstance() { return DEFAULT_INSTANCE; } @java.lang.Deprecated public static final com.google.protobuf.Parser PARSER = new com.google.protobuf.AbstractParser() { @java.lang.Override public CodeGeneratorRequest parsePartialFrom( com.google.protobuf.CodedInputStream input, com.google.protobuf.ExtensionRegistryLite extensionRegistry) throws com.google.protobuf.InvalidProtocolBufferException { Builder builder = newBuilder(); try { builder.mergeFrom(input, extensionRegistry); } catch (com.google.protobuf.InvalidProtocolBufferException e) { throw e.setUnfinishedMessage(builder.buildPartial()); } catch (com.google.protobuf.UninitializedMessageException e) { throw e.asInvalidProtocolBufferException().setUnfinishedMessage(builder.buildPartial()); } catch (java.io.IOException e) { throw new com.google.protobuf.InvalidProtocolBufferException(e) .setUnfinishedMessage(builder.buildPartial()); } return builder.buildPartial(); } }; public static com.google.protobuf.Parser parser() { return PARSER; } @java.lang.Override public com.google.protobuf.Parser getParserForType() { return PARSER; } @java.lang.Override public com.google.protobuf.compiler.PluginProtos.CodeGeneratorRequest getDefaultInstanceForType() { return DEFAULT_INSTANCE; } } public interface CodeGeneratorResponseOrBuilder extends // @@protoc_insertion_point(interface_extends:google.protobuf.compiler.CodeGeneratorResponse) com.google.protobuf.MessageOrBuilder { /** *
     * 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.
     * 
* * optional string error = 1; * @return Whether the error field is set. */ boolean hasError(); /** *
     * 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.
     * 
* * optional string error = 1; * @return The error. */ java.lang.String getError(); /** *
     * 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.
     * 
* * optional string error = 1; * @return The bytes for error. */ com.google.protobuf.ByteString getErrorBytes(); /** *
     * A bitmask of supported features that the code generator supports.
     * This is a bitwise "or" of values from the Feature enum.
     * 
* * optional uint64 supported_features = 2; * @return Whether the supportedFeatures field is set. */ boolean hasSupportedFeatures(); /** *
     * A bitmask of supported features that the code generator supports.
     * This is a bitwise "or" of values from the Feature enum.
     * 
* * optional uint64 supported_features = 2; * @return The supportedFeatures. */ long getSupportedFeatures(); /** * repeated .google.protobuf.compiler.CodeGeneratorResponse.File file = 15; */ java.util.List getFileList(); /** * repeated .google.protobuf.compiler.CodeGeneratorResponse.File file = 15; */ com.google.protobuf.compiler.PluginProtos.CodeGeneratorResponse.File getFile(int index); /** * repeated .google.protobuf.compiler.CodeGeneratorResponse.File file = 15; */ int getFileCount(); /** * repeated .google.protobuf.compiler.CodeGeneratorResponse.File file = 15; */ java.util.List getFileOrBuilderList(); /** * repeated .google.protobuf.compiler.CodeGeneratorResponse.File file = 15; */ com.google.protobuf.compiler.PluginProtos.CodeGeneratorResponse.FileOrBuilder getFileOrBuilder( int index); } /** *
   * The plugin writes an encoded CodeGeneratorResponse to stdout.
   * 
* * Protobuf type {@code google.protobuf.compiler.CodeGeneratorResponse} */ public static final class CodeGeneratorResponse extends com.google.protobuf.GeneratedMessageV3 implements // @@protoc_insertion_point(message_implements:google.protobuf.compiler.CodeGeneratorResponse) CodeGeneratorResponseOrBuilder { private static final long serialVersionUID = 0L; // Use CodeGeneratorResponse.newBuilder() to construct. private CodeGeneratorResponse(com.google.protobuf.GeneratedMessageV3.Builder builder) { super(builder); } private CodeGeneratorResponse() { error_ = ""; file_ = java.util.Collections.emptyList(); } @java.lang.Override @SuppressWarnings({"unused"}) protected java.lang.Object newInstance( UnusedPrivateParameter unused) { return new CodeGeneratorResponse(); } @java.lang.Override public final com.google.protobuf.UnknownFieldSet getUnknownFields() { return this.unknownFields; } public static final com.google.protobuf.Descriptors.Descriptor getDescriptor() { return com.google.protobuf.compiler.PluginProtos.internal_static_google_protobuf_compiler_CodeGeneratorResponse_descriptor; } @java.lang.Override protected com.google.protobuf.GeneratedMessageV3.FieldAccessorTable internalGetFieldAccessorTable() { return com.google.protobuf.compiler.PluginProtos.internal_static_google_protobuf_compiler_CodeGeneratorResponse_fieldAccessorTable .ensureFieldAccessorsInitialized( com.google.protobuf.compiler.PluginProtos.CodeGeneratorResponse.class, com.google.protobuf.compiler.PluginProtos.CodeGeneratorResponse.Builder.class); } /** *
     * Sync with code_generator.h.
     * 
* * Protobuf enum {@code google.protobuf.compiler.CodeGeneratorResponse.Feature} */ public enum Feature implements com.google.protobuf.ProtocolMessageEnum { /** * FEATURE_NONE = 0; */ FEATURE_NONE(0), /** * FEATURE_PROTO3_OPTIONAL = 1; */ FEATURE_PROTO3_OPTIONAL(1), ; /** * FEATURE_NONE = 0; */ public static final int FEATURE_NONE_VALUE = 0; /** * FEATURE_PROTO3_OPTIONAL = 1; */ public static final int FEATURE_PROTO3_OPTIONAL_VALUE = 1; public final int getNumber() { return value; } /** * @param value The numeric wire value of the corresponding enum entry. * @return The enum associated with the given numeric wire value. * @deprecated Use {@link #forNumber(int)} instead. */ @java.lang.Deprecated public static Feature valueOf(int value) { return forNumber(value); } /** * @param value The numeric wire value of the corresponding enum entry. * @return The enum associated with the given numeric wire value. */ public static Feature forNumber(int value) { switch (value) { case 0: return FEATURE_NONE; case 1: return FEATURE_PROTO3_OPTIONAL; default: return null; } } public static com.google.protobuf.Internal.EnumLiteMap internalGetValueMap() { return internalValueMap; } private static final com.google.protobuf.Internal.EnumLiteMap< Feature> internalValueMap = new com.google.protobuf.Internal.EnumLiteMap() { public Feature findValueByNumber(int number) { return Feature.forNumber(number); } }; public final com.google.protobuf.Descriptors.EnumValueDescriptor getValueDescriptor() { return getDescriptor().getValues().get(ordinal()); } public final com.google.protobuf.Descriptors.EnumDescriptor getDescriptorForType() { return getDescriptor(); } public static final com.google.protobuf.Descriptors.EnumDescriptor getDescriptor() { return com.google.protobuf.compiler.PluginProtos.CodeGeneratorResponse.getDescriptor().getEnumTypes().get(0); } private static final Feature[] VALUES = values(); public static Feature valueOf( com.google.protobuf.Descriptors.EnumValueDescriptor desc) { if (desc.getType() != getDescriptor()) { throw new java.lang.IllegalArgumentException( "EnumValueDescriptor is not for this type."); } return VALUES[desc.getIndex()]; } private final int value; private Feature(int value) { this.value = value; } // @@protoc_insertion_point(enum_scope:google.protobuf.compiler.CodeGeneratorResponse.Feature) } public interface FileOrBuilder extends // @@protoc_insertion_point(interface_extends:google.protobuf.compiler.CodeGeneratorResponse.File) com.google.protobuf.MessageOrBuilder { /** *
       * 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.
       * 
* * optional string name = 1; * @return Whether the name field is set. */ boolean hasName(); /** *
       * 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.
       * 
* * optional string name = 1; * @return The name. */ java.lang.String getName(); /** *
       * 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.
       * 
* * optional string name = 1; * @return The bytes for name. */ com.google.protobuf.ByteString getNameBytes(); /** *
       * 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.
       * 
* * optional string insertion_point = 2; * @return Whether the insertionPoint field is set. */ boolean hasInsertionPoint(); /** *
       * 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.
       * 
* * optional string insertion_point = 2; * @return The insertionPoint. */ java.lang.String getInsertionPoint(); /** *
       * 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.
       * 
* * optional string insertion_point = 2; * @return The bytes for insertionPoint. */ com.google.protobuf.ByteString getInsertionPointBytes(); /** *
       * The file contents.
       * 
* * optional string content = 15; * @return Whether the content field is set. */ boolean hasContent(); /** *
       * The file contents.
       * 
* * optional string content = 15; * @return The content. */ java.lang.String getContent(); /** *
       * The file contents.
       * 
* * optional string content = 15; * @return The bytes for content. */ com.google.protobuf.ByteString getContentBytes(); /** *
       * Information describing the file content being inserted. If an insertion
       * point is used, this information will be appropriately offset and inserted
       * into the code generation metadata for the generated files.
       * 
* * optional .google.protobuf.GeneratedCodeInfo generated_code_info = 16; * @return Whether the generatedCodeInfo field is set. */ boolean hasGeneratedCodeInfo(); /** *
       * Information describing the file content being inserted. If an insertion
       * point is used, this information will be appropriately offset and inserted
       * into the code generation metadata for the generated files.
       * 
* * optional .google.protobuf.GeneratedCodeInfo generated_code_info = 16; * @return The generatedCodeInfo. */ com.google.protobuf.DescriptorProtos.GeneratedCodeInfo getGeneratedCodeInfo(); /** *
       * Information describing the file content being inserted. If an insertion
       * point is used, this information will be appropriately offset and inserted
       * into the code generation metadata for the generated files.
       * 
* * optional .google.protobuf.GeneratedCodeInfo generated_code_info = 16; */ com.google.protobuf.DescriptorProtos.GeneratedCodeInfoOrBuilder getGeneratedCodeInfoOrBuilder(); } /** *
     * Represents a single generated file.
     * 
* * Protobuf type {@code google.protobuf.compiler.CodeGeneratorResponse.File} */ public static final class File extends com.google.protobuf.GeneratedMessageV3 implements // @@protoc_insertion_point(message_implements:google.protobuf.compiler.CodeGeneratorResponse.File) FileOrBuilder { private static final long serialVersionUID = 0L; // Use File.newBuilder() to construct. private File(com.google.protobuf.GeneratedMessageV3.Builder builder) { super(builder); } private File() { name_ = ""; insertionPoint_ = ""; content_ = ""; } @java.lang.Override @SuppressWarnings({"unused"}) protected java.lang.Object newInstance( UnusedPrivateParameter unused) { return new File(); } @java.lang.Override public final com.google.protobuf.UnknownFieldSet getUnknownFields() { return this.unknownFields; } public static final com.google.protobuf.Descriptors.Descriptor getDescriptor() { return com.google.protobuf.compiler.PluginProtos.internal_static_google_protobuf_compiler_CodeGeneratorResponse_File_descriptor; } @java.lang.Override protected com.google.protobuf.GeneratedMessageV3.FieldAccessorTable internalGetFieldAccessorTable() { return com.google.protobuf.compiler.PluginProtos.internal_static_google_protobuf_compiler_CodeGeneratorResponse_File_fieldAccessorTable .ensureFieldAccessorsInitialized( com.google.protobuf.compiler.PluginProtos.CodeGeneratorResponse.File.class, com.google.protobuf.compiler.PluginProtos.CodeGeneratorResponse.File.Builder.class); } private int bitField0_; public static final int NAME_FIELD_NUMBER = 1; @SuppressWarnings("serial") private volatile java.lang.Object name_ = ""; /** *
       * 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.
       * 
* * optional string name = 1; * @return Whether the name field is set. */ @java.lang.Override public boolean hasName() { return ((bitField0_ & 0x00000001) != 0); } /** *
       * 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.
       * 
* * optional string name = 1; * @return The name. */ @java.lang.Override public java.lang.String getName() { java.lang.Object ref = name_; if (ref instanceof java.lang.String) { return (java.lang.String) ref; } else { com.google.protobuf.ByteString bs = (com.google.protobuf.ByteString) ref; java.lang.String s = bs.toStringUtf8(); if (bs.isValidUtf8()) { name_ = s; } return s; } } /** *
       * 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.
       * 
* * optional string name = 1; * @return The bytes for name. */ @java.lang.Override public com.google.protobuf.ByteString getNameBytes() { java.lang.Object ref = name_; if (ref instanceof java.lang.String) { com.google.protobuf.ByteString b = com.google.protobuf.ByteString.copyFromUtf8( (java.lang.String) ref); name_ = b; return b; } else { return (com.google.protobuf.ByteString) ref; } } public static final int INSERTION_POINT_FIELD_NUMBER = 2; @SuppressWarnings("serial") private volatile java.lang.Object insertionPoint_ = ""; /** *
       * 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.
       * 
* * optional string insertion_point = 2; * @return Whether the insertionPoint field is set. */ @java.lang.Override public boolean hasInsertionPoint() { return ((bitField0_ & 0x00000002) != 0); } /** *
       * 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.
       * 
* * optional string insertion_point = 2; * @return The insertionPoint. */ @java.lang.Override public java.lang.String getInsertionPoint() { java.lang.Object ref = insertionPoint_; if (ref instanceof java.lang.String) { return (java.lang.String) ref; } else { com.google.protobuf.ByteString bs = (com.google.protobuf.ByteString) ref; java.lang.String s = bs.toStringUtf8(); if (bs.isValidUtf8()) { insertionPoint_ = s; } return s; } } /** *
       * 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.
       * 
* * optional string insertion_point = 2; * @return The bytes for insertionPoint. */ @java.lang.Override public com.google.protobuf.ByteString getInsertionPointBytes() { java.lang.Object ref = insertionPoint_; if (ref instanceof java.lang.String) { com.google.protobuf.ByteString b = com.google.protobuf.ByteString.copyFromUtf8( (java.lang.String) ref); insertionPoint_ = b; return b; } else { return (com.google.protobuf.ByteString) ref; } } public static final int CONTENT_FIELD_NUMBER = 15; @SuppressWarnings("serial") private volatile java.lang.Object content_ = ""; /** *
       * The file contents.
       * 
* * optional string content = 15; * @return Whether the content field is set. */ @java.lang.Override public boolean hasContent() { return ((bitField0_ & 0x00000004) != 0); } /** *
       * The file contents.
       * 
* * optional string content = 15; * @return The content. */ @java.lang.Override public java.lang.String getContent() { java.lang.Object ref = content_; if (ref instanceof java.lang.String) { return (java.lang.String) ref; } else { com.google.protobuf.ByteString bs = (com.google.protobuf.ByteString) ref; java.lang.String s = bs.toStringUtf8(); if (bs.isValidUtf8()) { content_ = s; } return s; } } /** *
       * The file contents.
       * 
* * optional string content = 15; * @return The bytes for content. */ @java.lang.Override public com.google.protobuf.ByteString getContentBytes() { java.lang.Object ref = content_; if (ref instanceof java.lang.String) { com.google.protobuf.ByteString b = com.google.protobuf.ByteString.copyFromUtf8( (java.lang.String) ref); content_ = b; return b; } else { return (com.google.protobuf.ByteString) ref; } } public static final int GENERATED_CODE_INFO_FIELD_NUMBER = 16; private com.google.protobuf.DescriptorProtos.GeneratedCodeInfo generatedCodeInfo_; /** *
       * Information describing the file content being inserted. If an insertion
       * point is used, this information will be appropriately offset and inserted
       * into the code generation metadata for the generated files.
       * 
* * optional .google.protobuf.GeneratedCodeInfo generated_code_info = 16; * @return Whether the generatedCodeInfo field is set. */ @java.lang.Override public boolean hasGeneratedCodeInfo() { return ((bitField0_ & 0x00000008) != 0); } /** *
       * Information describing the file content being inserted. If an insertion
       * point is used, this information will be appropriately offset and inserted
       * into the code generation metadata for the generated files.
       * 
* * optional .google.protobuf.GeneratedCodeInfo generated_code_info = 16; * @return The generatedCodeInfo. */ @java.lang.Override public com.google.protobuf.DescriptorProtos.GeneratedCodeInfo getGeneratedCodeInfo() { return generatedCodeInfo_ == null ? com.google.protobuf.DescriptorProtos.GeneratedCodeInfo.getDefaultInstance() : generatedCodeInfo_; } /** *
       * Information describing the file content being inserted. If an insertion
       * point is used, this information will be appropriately offset and inserted
       * into the code generation metadata for the generated files.
       * 
* * optional .google.protobuf.GeneratedCodeInfo generated_code_info = 16; */ @java.lang.Override public com.google.protobuf.DescriptorProtos.GeneratedCodeInfoOrBuilder getGeneratedCodeInfoOrBuilder() { return generatedCodeInfo_ == null ? com.google.protobuf.DescriptorProtos.GeneratedCodeInfo.getDefaultInstance() : generatedCodeInfo_; } private byte memoizedIsInitialized = -1; @java.lang.Override public final boolean isInitialized() { byte isInitialized = memoizedIsInitialized; if (isInitialized == 1) return true; if (isInitialized == 0) return false; memoizedIsInitialized = 1; return true; } @java.lang.Override public void writeTo(com.google.protobuf.CodedOutputStream output) throws java.io.IOException { if (((bitField0_ & 0x00000001) != 0)) { com.google.protobuf.GeneratedMessageV3.writeString(output, 1, name_); } if (((bitField0_ & 0x00000002) != 0)) { com.google.protobuf.GeneratedMessageV3.writeString(output, 2, insertionPoint_); } if (((bitField0_ & 0x00000004) != 0)) { com.google.protobuf.GeneratedMessageV3.writeString(output, 15, content_); } if (((bitField0_ & 0x00000008) != 0)) { output.writeMessage(16, getGeneratedCodeInfo()); } getUnknownFields().writeTo(output); } @java.lang.Override public int getSerializedSize() { int size = memoizedSize; if (size != -1) return size; size = 0; if (((bitField0_ & 0x00000001) != 0)) { size += com.google.protobuf.GeneratedMessageV3.computeStringSize(1, name_); } if (((bitField0_ & 0x00000002) != 0)) { size += com.google.protobuf.GeneratedMessageV3.computeStringSize(2, insertionPoint_); } if (((bitField0_ & 0x00000004) != 0)) { size += com.google.protobuf.GeneratedMessageV3.computeStringSize(15, content_); } if (((bitField0_ & 0x00000008) != 0)) { size += com.google.protobuf.CodedOutputStream .computeMessageSize(16, getGeneratedCodeInfo()); } size += getUnknownFields().getSerializedSize(); memoizedSize = size; return size; } @java.lang.Override public boolean equals(final java.lang.Object obj) { if (obj == this) { return true; } if (!(obj instanceof com.google.protobuf.compiler.PluginProtos.CodeGeneratorResponse.File)) { return super.equals(obj); } com.google.protobuf.compiler.PluginProtos.CodeGeneratorResponse.File other = (com.google.protobuf.compiler.PluginProtos.CodeGeneratorResponse.File) obj; if (hasName() != other.hasName()) return false; if (hasName()) { if (!getName() .equals(other.getName())) return false; } if (hasInsertionPoint() != other.hasInsertionPoint()) return false; if (hasInsertionPoint()) { if (!getInsertionPoint() .equals(other.getInsertionPoint())) return false; } if (hasContent() != other.hasContent()) return false; if (hasContent()) { if (!getContent() .equals(other.getContent())) return false; } if (hasGeneratedCodeInfo() != other.hasGeneratedCodeInfo()) return false; if (hasGeneratedCodeInfo()) { if (!getGeneratedCodeInfo() .equals(other.getGeneratedCodeInfo())) return false; } if (!getUnknownFields().equals(other.getUnknownFields())) return false; return true; } @java.lang.Override public int hashCode() { if (memoizedHashCode != 0) { return memoizedHashCode; } int hash = 41; hash = (19 * hash) + getDescriptor().hashCode(); if (hasName()) { hash = (37 * hash) + NAME_FIELD_NUMBER; hash = (53 * hash) + getName().hashCode(); } if (hasInsertionPoint()) { hash = (37 * hash) + INSERTION_POINT_FIELD_NUMBER; hash = (53 * hash) + getInsertionPoint().hashCode(); } if (hasContent()) { hash = (37 * hash) + CONTENT_FIELD_NUMBER; hash = (53 * hash) + getContent().hashCode(); } if (hasGeneratedCodeInfo()) { hash = (37 * hash) + GENERATED_CODE_INFO_FIELD_NUMBER; hash = (53 * hash) + getGeneratedCodeInfo().hashCode(); } hash = (29 * hash) + getUnknownFields().hashCode(); memoizedHashCode = hash; return hash; } public static com.google.protobuf.compiler.PluginProtos.CodeGeneratorResponse.File parseFrom( java.nio.ByteBuffer data) throws com.google.protobuf.InvalidProtocolBufferException { return PARSER.parseFrom(data); } public static com.google.protobuf.compiler.PluginProtos.CodeGeneratorResponse.File parseFrom( java.nio.ByteBuffer data, com.google.protobuf.ExtensionRegistryLite extensionRegistry) throws com.google.protobuf.InvalidProtocolBufferException { return PARSER.parseFrom(data, extensionRegistry); } public static com.google.protobuf.compiler.PluginProtos.CodeGeneratorResponse.File parseFrom( com.google.protobuf.ByteString data) throws com.google.protobuf.InvalidProtocolBufferException { return PARSER.parseFrom(data); } public static com.google.protobuf.compiler.PluginProtos.CodeGeneratorResponse.File parseFrom( com.google.protobuf.ByteString data, com.google.protobuf.ExtensionRegistryLite extensionRegistry) throws com.google.protobuf.InvalidProtocolBufferException { return PARSER.parseFrom(data, extensionRegistry); } public static com.google.protobuf.compiler.PluginProtos.CodeGeneratorResponse.File parseFrom(byte[] data) throws com.google.protobuf.InvalidProtocolBufferException { return PARSER.parseFrom(data); } public static com.google.protobuf.compiler.PluginProtos.CodeGeneratorResponse.File parseFrom( byte[] data, com.google.protobuf.ExtensionRegistryLite extensionRegistry) throws com.google.protobuf.InvalidProtocolBufferException { return PARSER.parseFrom(data, extensionRegistry); } public static com.google.protobuf.compiler.PluginProtos.CodeGeneratorResponse.File parseFrom(java.io.InputStream input) throws java.io.IOException { return com.google.protobuf.GeneratedMessageV3 .parseWithIOException(PARSER, input); } public static com.google.protobuf.compiler.PluginProtos.CodeGeneratorResponse.File parseFrom( java.io.InputStream input, com.google.protobuf.ExtensionRegistryLite extensionRegistry) throws java.io.IOException { return com.google.protobuf.GeneratedMessageV3 .parseWithIOException(PARSER, input, extensionRegistry); } public static com.google.protobuf.compiler.PluginProtos.CodeGeneratorResponse.File parseDelimitedFrom(java.io.InputStream input) throws java.io.IOException { return com.google.protobuf.GeneratedMessageV3 .parseDelimitedWithIOException(PARSER, input); } public static com.google.protobuf.compiler.PluginProtos.CodeGeneratorResponse.File parseDelimitedFrom( java.io.InputStream input, com.google.protobuf.ExtensionRegistryLite extensionRegistry) throws java.io.IOException { return com.google.protobuf.GeneratedMessageV3 .parseDelimitedWithIOException(PARSER, input, extensionRegistry); } public static com.google.protobuf.compiler.PluginProtos.CodeGeneratorResponse.File parseFrom( com.google.protobuf.CodedInputStream input) throws java.io.IOException { return com.google.protobuf.GeneratedMessageV3 .parseWithIOException(PARSER, input); } public static com.google.protobuf.compiler.PluginProtos.CodeGeneratorResponse.File parseFrom( com.google.protobuf.CodedInputStream input, com.google.protobuf.ExtensionRegistryLite extensionRegistry) throws java.io.IOException { return com.google.protobuf.GeneratedMessageV3 .parseWithIOException(PARSER, input, extensionRegistry); } @java.lang.Override public Builder newBuilderForType() { return newBuilder(); } public static Builder newBuilder() { return DEFAULT_INSTANCE.toBuilder(); } public static Builder newBuilder(com.google.protobuf.compiler.PluginProtos.CodeGeneratorResponse.File prototype) { return DEFAULT_INSTANCE.toBuilder().mergeFrom(prototype); } @java.lang.Override public Builder toBuilder() { return this == DEFAULT_INSTANCE ? new Builder() : new Builder().mergeFrom(this); } @java.lang.Override protected Builder newBuilderForType( com.google.protobuf.GeneratedMessageV3.BuilderParent parent) { Builder builder = new Builder(parent); return builder; } /** *
       * Represents a single generated file.
       * 
* * Protobuf type {@code google.protobuf.compiler.CodeGeneratorResponse.File} */ public static final class Builder extends com.google.protobuf.GeneratedMessageV3.Builder implements // @@protoc_insertion_point(builder_implements:google.protobuf.compiler.CodeGeneratorResponse.File) com.google.protobuf.compiler.PluginProtos.CodeGeneratorResponse.FileOrBuilder { public static final com.google.protobuf.Descriptors.Descriptor getDescriptor() { return com.google.protobuf.compiler.PluginProtos.internal_static_google_protobuf_compiler_CodeGeneratorResponse_File_descriptor; } @java.lang.Override protected com.google.protobuf.GeneratedMessageV3.FieldAccessorTable internalGetFieldAccessorTable() { return com.google.protobuf.compiler.PluginProtos.internal_static_google_protobuf_compiler_CodeGeneratorResponse_File_fieldAccessorTable .ensureFieldAccessorsInitialized( com.google.protobuf.compiler.PluginProtos.CodeGeneratorResponse.File.class, com.google.protobuf.compiler.PluginProtos.CodeGeneratorResponse.File.Builder.class); } // Construct using com.google.protobuf.compiler.PluginProtos.CodeGeneratorResponse.File.newBuilder() private Builder() { maybeForceBuilderInitialization(); } private Builder( com.google.protobuf.GeneratedMessageV3.BuilderParent parent) { super(parent); maybeForceBuilderInitialization(); } private void maybeForceBuilderInitialization() { if (com.google.protobuf.GeneratedMessageV3 .alwaysUseFieldBuilders) { getGeneratedCodeInfoFieldBuilder(); } } @java.lang.Override public Builder clear() { super.clear(); bitField0_ = 0; name_ = ""; insertionPoint_ = ""; content_ = ""; generatedCodeInfo_ = null; if (generatedCodeInfoBuilder_ != null) { generatedCodeInfoBuilder_.dispose(); generatedCodeInfoBuilder_ = null; } return this; } @java.lang.Override public com.google.protobuf.Descriptors.Descriptor getDescriptorForType() { return com.google.protobuf.compiler.PluginProtos.internal_static_google_protobuf_compiler_CodeGeneratorResponse_File_descriptor; } @java.lang.Override public com.google.protobuf.compiler.PluginProtos.CodeGeneratorResponse.File getDefaultInstanceForType() { return com.google.protobuf.compiler.PluginProtos.CodeGeneratorResponse.File.getDefaultInstance(); } @java.lang.Override public com.google.protobuf.compiler.PluginProtos.CodeGeneratorResponse.File build() { com.google.protobuf.compiler.PluginProtos.CodeGeneratorResponse.File result = buildPartial(); if (!result.isInitialized()) { throw newUninitializedMessageException(result); } return result; } @java.lang.Override public com.google.protobuf.compiler.PluginProtos.CodeGeneratorResponse.File buildPartial() { com.google.protobuf.compiler.PluginProtos.CodeGeneratorResponse.File result = new com.google.protobuf.compiler.PluginProtos.CodeGeneratorResponse.File(this); if (bitField0_ != 0) { buildPartial0(result); } onBuilt(); return result; } private void buildPartial0(com.google.protobuf.compiler.PluginProtos.CodeGeneratorResponse.File result) { int from_bitField0_ = bitField0_; int to_bitField0_ = 0; if (((from_bitField0_ & 0x00000001) != 0)) { result.name_ = name_; to_bitField0_ |= 0x00000001; } if (((from_bitField0_ & 0x00000002) != 0)) { result.insertionPoint_ = insertionPoint_; to_bitField0_ |= 0x00000002; } if (((from_bitField0_ & 0x00000004) != 0)) { result.content_ = content_; to_bitField0_ |= 0x00000004; } if (((from_bitField0_ & 0x00000008) != 0)) { result.generatedCodeInfo_ = generatedCodeInfoBuilder_ == null ? generatedCodeInfo_ : generatedCodeInfoBuilder_.build(); to_bitField0_ |= 0x00000008; } result.bitField0_ |= to_bitField0_; } @java.lang.Override public Builder clone() { return super.clone(); } @java.lang.Override public Builder setField( com.google.protobuf.Descriptors.FieldDescriptor field, java.lang.Object value) { return super.setField(field, value); } @java.lang.Override public Builder clearField( com.google.protobuf.Descriptors.FieldDescriptor field) { return super.clearField(field); } @java.lang.Override public Builder clearOneof( com.google.protobuf.Descriptors.OneofDescriptor oneof) { return super.clearOneof(oneof); } @java.lang.Override public Builder setRepeatedField( com.google.protobuf.Descriptors.FieldDescriptor field, int index, java.lang.Object value) { return super.setRepeatedField(field, index, value); } @java.lang.Override public Builder addRepeatedField( com.google.protobuf.Descriptors.FieldDescriptor field, java.lang.Object value) { return super.addRepeatedField(field, value); } @java.lang.Override public Builder mergeFrom(com.google.protobuf.Message other) { if (other instanceof com.google.protobuf.compiler.PluginProtos.CodeGeneratorResponse.File) { return mergeFrom((com.google.protobuf.compiler.PluginProtos.CodeGeneratorResponse.File)other); } else { super.mergeFrom(other); return this; } } public Builder mergeFrom(com.google.protobuf.compiler.PluginProtos.CodeGeneratorResponse.File other) { if (other == com.google.protobuf.compiler.PluginProtos.CodeGeneratorResponse.File.getDefaultInstance()) return this; if (other.hasName()) { name_ = other.name_; bitField0_ |= 0x00000001; onChanged(); } if (other.hasInsertionPoint()) { insertionPoint_ = other.insertionPoint_; bitField0_ |= 0x00000002; onChanged(); } if (other.hasContent()) { content_ = other.content_; bitField0_ |= 0x00000004; onChanged(); } if (other.hasGeneratedCodeInfo()) { mergeGeneratedCodeInfo(other.getGeneratedCodeInfo()); } this.mergeUnknownFields(other.getUnknownFields()); onChanged(); return this; } @java.lang.Override public final boolean isInitialized() { return true; } @java.lang.Override public Builder mergeFrom( com.google.protobuf.CodedInputStream input, com.google.protobuf.ExtensionRegistryLite extensionRegistry) throws java.io.IOException { if (extensionRegistry == null) { throw new java.lang.NullPointerException(); } try { boolean done = false; while (!done) { int tag = input.readTag(); switch (tag) { case 0: done = true; break; case 10: { name_ = input.readBytes(); bitField0_ |= 0x00000001; break; } // case 10 case 18: { insertionPoint_ = input.readBytes(); bitField0_ |= 0x00000002; break; } // case 18 case 122: { content_ = input.readBytes(); bitField0_ |= 0x00000004; break; } // case 122 case 130: { input.readMessage( getGeneratedCodeInfoFieldBuilder().getBuilder(), extensionRegistry); bitField0_ |= 0x00000008; break; } // case 130 default: { if (!super.parseUnknownField(input, extensionRegistry, tag)) { done = true; // was an endgroup tag } break; } // default: } // switch (tag) } // while (!done) } catch (com.google.protobuf.InvalidProtocolBufferException e) { throw e.unwrapIOException(); } finally { onChanged(); } // finally return this; } private int bitField0_; private java.lang.Object name_ = ""; /** *
         * 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.
         * 
* * optional string name = 1; * @return Whether the name field is set. */ public boolean hasName() { return ((bitField0_ & 0x00000001) != 0); } /** *
         * 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.
         * 
* * optional string name = 1; * @return The name. */ public java.lang.String getName() { java.lang.Object ref = name_; if (!(ref instanceof java.lang.String)) { com.google.protobuf.ByteString bs = (com.google.protobuf.ByteString) ref; java.lang.String s = bs.toStringUtf8(); if (bs.isValidUtf8()) { name_ = s; } return s; } else { return (java.lang.String) ref; } } /** *
         * 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.
         * 
* * optional string name = 1; * @return The bytes for name. */ public com.google.protobuf.ByteString getNameBytes() { java.lang.Object ref = name_; if (ref instanceof String) { com.google.protobuf.ByteString b = com.google.protobuf.ByteString.copyFromUtf8( (java.lang.String) ref); name_ = b; return b; } else { return (com.google.protobuf.ByteString) ref; } } /** *
         * 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.
         * 
* * optional string name = 1; * @param value The name to set. * @return This builder for chaining. */ public Builder setName( java.lang.String value) { if (value == null) { throw new NullPointerException(); } name_ = value; bitField0_ |= 0x00000001; onChanged(); return this; } /** *
         * 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.
         * 
* * optional string name = 1; * @return This builder for chaining. */ public Builder clearName() { name_ = getDefaultInstance().getName(); bitField0_ = (bitField0_ & ~0x00000001); onChanged(); return this; } /** *
         * 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.
         * 
* * optional string name = 1; * @param value The bytes for name to set. * @return This builder for chaining. */ public Builder setNameBytes( com.google.protobuf.ByteString value) { if (value == null) { throw new NullPointerException(); } name_ = value; bitField0_ |= 0x00000001; onChanged(); return this; } private java.lang.Object insertionPoint_ = ""; /** *
         * 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.
         * 
* * optional string insertion_point = 2; * @return Whether the insertionPoint field is set. */ public boolean hasInsertionPoint() { return ((bitField0_ & 0x00000002) != 0); } /** *
         * 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.
         * 
* * optional string insertion_point = 2; * @return The insertionPoint. */ public java.lang.String getInsertionPoint() { java.lang.Object ref = insertionPoint_; if (!(ref instanceof java.lang.String)) { com.google.protobuf.ByteString bs = (com.google.protobuf.ByteString) ref; java.lang.String s = bs.toStringUtf8(); if (bs.isValidUtf8()) { insertionPoint_ = s; } return s; } else { return (java.lang.String) ref; } } /** *
         * 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.
         * 
* * optional string insertion_point = 2; * @return The bytes for insertionPoint. */ public com.google.protobuf.ByteString getInsertionPointBytes() { java.lang.Object ref = insertionPoint_; if (ref instanceof String) { com.google.protobuf.ByteString b = com.google.protobuf.ByteString.copyFromUtf8( (java.lang.String) ref); insertionPoint_ = b; return b; } else { return (com.google.protobuf.ByteString) ref; } } /** *
         * 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.
         * 
* * optional string insertion_point = 2; * @param value The insertionPoint to set. * @return This builder for chaining. */ public Builder setInsertionPoint( java.lang.String value) { if (value == null) { throw new NullPointerException(); } insertionPoint_ = value; bitField0_ |= 0x00000002; onChanged(); return this; } /** *
         * 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.
         * 
* * optional string insertion_point = 2; * @return This builder for chaining. */ public Builder clearInsertionPoint() { insertionPoint_ = getDefaultInstance().getInsertionPoint(); bitField0_ = (bitField0_ & ~0x00000002); onChanged(); return this; } /** *
         * 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.
         * 
* * optional string insertion_point = 2; * @param value The bytes for insertionPoint to set. * @return This builder for chaining. */ public Builder setInsertionPointBytes( com.google.protobuf.ByteString value) { if (value == null) { throw new NullPointerException(); } insertionPoint_ = value; bitField0_ |= 0x00000002; onChanged(); return this; } private java.lang.Object content_ = ""; /** *
         * The file contents.
         * 
* * optional string content = 15; * @return Whether the content field is set. */ public boolean hasContent() { return ((bitField0_ & 0x00000004) != 0); } /** *
         * The file contents.
         * 
* * optional string content = 15; * @return The content. */ public java.lang.String getContent() { java.lang.Object ref = content_; if (!(ref instanceof java.lang.String)) { com.google.protobuf.ByteString bs = (com.google.protobuf.ByteString) ref; java.lang.String s = bs.toStringUtf8(); if (bs.isValidUtf8()) { content_ = s; } return s; } else { return (java.lang.String) ref; } } /** *
         * The file contents.
         * 
* * optional string content = 15; * @return The bytes for content. */ public com.google.protobuf.ByteString getContentBytes() { java.lang.Object ref = content_; if (ref instanceof String) { com.google.protobuf.ByteString b = com.google.protobuf.ByteString.copyFromUtf8( (java.lang.String) ref); content_ = b; return b; } else { return (com.google.protobuf.ByteString) ref; } } /** *
         * The file contents.
         * 
* * optional string content = 15; * @param value The content to set. * @return This builder for chaining. */ public Builder setContent( java.lang.String value) { if (value == null) { throw new NullPointerException(); } content_ = value; bitField0_ |= 0x00000004; onChanged(); return this; } /** *
         * The file contents.
         * 
* * optional string content = 15; * @return This builder for chaining. */ public Builder clearContent() { content_ = getDefaultInstance().getContent(); bitField0_ = (bitField0_ & ~0x00000004); onChanged(); return this; } /** *
         * The file contents.
         * 
* * optional string content = 15; * @param value The bytes for content to set. * @return This builder for chaining. */ public Builder setContentBytes( com.google.protobuf.ByteString value) { if (value == null) { throw new NullPointerException(); } content_ = value; bitField0_ |= 0x00000004; onChanged(); return this; } private com.google.protobuf.DescriptorProtos.GeneratedCodeInfo generatedCodeInfo_; private com.google.protobuf.SingleFieldBuilderV3< com.google.protobuf.DescriptorProtos.GeneratedCodeInfo, com.google.protobuf.DescriptorProtos.GeneratedCodeInfo.Builder, com.google.protobuf.DescriptorProtos.GeneratedCodeInfoOrBuilder> generatedCodeInfoBuilder_; /** *
         * Information describing the file content being inserted. If an insertion
         * point is used, this information will be appropriately offset and inserted
         * into the code generation metadata for the generated files.
         * 
* * optional .google.protobuf.GeneratedCodeInfo generated_code_info = 16; * @return Whether the generatedCodeInfo field is set. */ public boolean hasGeneratedCodeInfo() { return ((bitField0_ & 0x00000008) != 0); } /** *
         * Information describing the file content being inserted. If an insertion
         * point is used, this information will be appropriately offset and inserted
         * into the code generation metadata for the generated files.
         * 
* * optional .google.protobuf.GeneratedCodeInfo generated_code_info = 16; * @return The generatedCodeInfo. */ public com.google.protobuf.DescriptorProtos.GeneratedCodeInfo getGeneratedCodeInfo() { if (generatedCodeInfoBuilder_ == null) { return generatedCodeInfo_ == null ? com.google.protobuf.DescriptorProtos.GeneratedCodeInfo.getDefaultInstance() : generatedCodeInfo_; } else { return generatedCodeInfoBuilder_.getMessage(); } } /** *
         * Information describing the file content being inserted. If an insertion
         * point is used, this information will be appropriately offset and inserted
         * into the code generation metadata for the generated files.
         * 
* * optional .google.protobuf.GeneratedCodeInfo generated_code_info = 16; */ public Builder setGeneratedCodeInfo(com.google.protobuf.DescriptorProtos.GeneratedCodeInfo value) { if (generatedCodeInfoBuilder_ == null) { if (value == null) { throw new NullPointerException(); } generatedCodeInfo_ = value; } else { generatedCodeInfoBuilder_.setMessage(value); } bitField0_ |= 0x00000008; onChanged(); return this; } /** *
         * Information describing the file content being inserted. If an insertion
         * point is used, this information will be appropriately offset and inserted
         * into the code generation metadata for the generated files.
         * 
* * optional .google.protobuf.GeneratedCodeInfo generated_code_info = 16; */ public Builder setGeneratedCodeInfo( com.google.protobuf.DescriptorProtos.GeneratedCodeInfo.Builder builderForValue) { if (generatedCodeInfoBuilder_ == null) { generatedCodeInfo_ = builderForValue.build(); } else { generatedCodeInfoBuilder_.setMessage(builderForValue.build()); } bitField0_ |= 0x00000008; onChanged(); return this; } /** *
         * Information describing the file content being inserted. If an insertion
         * point is used, this information will be appropriately offset and inserted
         * into the code generation metadata for the generated files.
         * 
* * optional .google.protobuf.GeneratedCodeInfo generated_code_info = 16; */ public Builder mergeGeneratedCodeInfo(com.google.protobuf.DescriptorProtos.GeneratedCodeInfo value) { if (generatedCodeInfoBuilder_ == null) { if (((bitField0_ & 0x00000008) != 0) && generatedCodeInfo_ != null && generatedCodeInfo_ != com.google.protobuf.DescriptorProtos.GeneratedCodeInfo.getDefaultInstance()) { getGeneratedCodeInfoBuilder().mergeFrom(value); } else { generatedCodeInfo_ = value; } } else { generatedCodeInfoBuilder_.mergeFrom(value); } bitField0_ |= 0x00000008; onChanged(); return this; } /** *
         * Information describing the file content being inserted. If an insertion
         * point is used, this information will be appropriately offset and inserted
         * into the code generation metadata for the generated files.
         * 
* * optional .google.protobuf.GeneratedCodeInfo generated_code_info = 16; */ public Builder clearGeneratedCodeInfo() { bitField0_ = (bitField0_ & ~0x00000008); generatedCodeInfo_ = null; if (generatedCodeInfoBuilder_ != null) { generatedCodeInfoBuilder_.dispose(); generatedCodeInfoBuilder_ = null; } onChanged(); return this; } /** *
         * Information describing the file content being inserted. If an insertion
         * point is used, this information will be appropriately offset and inserted
         * into the code generation metadata for the generated files.
         * 
* * optional .google.protobuf.GeneratedCodeInfo generated_code_info = 16; */ public com.google.protobuf.DescriptorProtos.GeneratedCodeInfo.Builder getGeneratedCodeInfoBuilder() { bitField0_ |= 0x00000008; onChanged(); return getGeneratedCodeInfoFieldBuilder().getBuilder(); } /** *
         * Information describing the file content being inserted. If an insertion
         * point is used, this information will be appropriately offset and inserted
         * into the code generation metadata for the generated files.
         * 
* * optional .google.protobuf.GeneratedCodeInfo generated_code_info = 16; */ public com.google.protobuf.DescriptorProtos.GeneratedCodeInfoOrBuilder getGeneratedCodeInfoOrBuilder() { if (generatedCodeInfoBuilder_ != null) { return generatedCodeInfoBuilder_.getMessageOrBuilder(); } else { return generatedCodeInfo_ == null ? com.google.protobuf.DescriptorProtos.GeneratedCodeInfo.getDefaultInstance() : generatedCodeInfo_; } } /** *
         * Information describing the file content being inserted. If an insertion
         * point is used, this information will be appropriately offset and inserted
         * into the code generation metadata for the generated files.
         * 
* * optional .google.protobuf.GeneratedCodeInfo generated_code_info = 16; */ private com.google.protobuf.SingleFieldBuilderV3< com.google.protobuf.DescriptorProtos.GeneratedCodeInfo, com.google.protobuf.DescriptorProtos.GeneratedCodeInfo.Builder, com.google.protobuf.DescriptorProtos.GeneratedCodeInfoOrBuilder> getGeneratedCodeInfoFieldBuilder() { if (generatedCodeInfoBuilder_ == null) { generatedCodeInfoBuilder_ = new com.google.protobuf.SingleFieldBuilderV3< com.google.protobuf.DescriptorProtos.GeneratedCodeInfo, com.google.protobuf.DescriptorProtos.GeneratedCodeInfo.Builder, com.google.protobuf.DescriptorProtos.GeneratedCodeInfoOrBuilder>( getGeneratedCodeInfo(), getParentForChildren(), isClean()); generatedCodeInfo_ = null; } return generatedCodeInfoBuilder_; } @java.lang.Override public final Builder setUnknownFields( final com.google.protobuf.UnknownFieldSet unknownFields) { return super.setUnknownFields(unknownFields); } @java.lang.Override public final Builder mergeUnknownFields( final com.google.protobuf.UnknownFieldSet unknownFields) { return super.mergeUnknownFields(unknownFields); } // @@protoc_insertion_point(builder_scope:google.protobuf.compiler.CodeGeneratorResponse.File) } // @@protoc_insertion_point(class_scope:google.protobuf.compiler.CodeGeneratorResponse.File) private static final com.google.protobuf.compiler.PluginProtos.CodeGeneratorResponse.File DEFAULT_INSTANCE; static { DEFAULT_INSTANCE = new com.google.protobuf.compiler.PluginProtos.CodeGeneratorResponse.File(); } public static com.google.protobuf.compiler.PluginProtos.CodeGeneratorResponse.File getDefaultInstance() { return DEFAULT_INSTANCE; } @java.lang.Deprecated public static final com.google.protobuf.Parser PARSER = new com.google.protobuf.AbstractParser() { @java.lang.Override public File parsePartialFrom( com.google.protobuf.CodedInputStream input, com.google.protobuf.ExtensionRegistryLite extensionRegistry) throws com.google.protobuf.InvalidProtocolBufferException { Builder builder = newBuilder(); try { builder.mergeFrom(input, extensionRegistry); } catch (com.google.protobuf.InvalidProtocolBufferException e) { throw e.setUnfinishedMessage(builder.buildPartial()); } catch (com.google.protobuf.UninitializedMessageException e) { throw e.asInvalidProtocolBufferException().setUnfinishedMessage(builder.buildPartial()); } catch (java.io.IOException e) { throw new com.google.protobuf.InvalidProtocolBufferException(e) .setUnfinishedMessage(builder.buildPartial()); } return builder.buildPartial(); } }; public static com.google.protobuf.Parser parser() { return PARSER; } @java.lang.Override public com.google.protobuf.Parser getParserForType() { return PARSER; } @java.lang.Override public com.google.protobuf.compiler.PluginProtos.CodeGeneratorResponse.File getDefaultInstanceForType() { return DEFAULT_INSTANCE; } } private int bitField0_; public static final int ERROR_FIELD_NUMBER = 1; @SuppressWarnings("serial") private volatile java.lang.Object error_ = ""; /** *
     * 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.
     * 
* * optional string error = 1; * @return Whether the error field is set. */ @java.lang.Override public boolean hasError() { return ((bitField0_ & 0x00000001) != 0); } /** *
     * 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.
     * 
* * optional string error = 1; * @return The error. */ @java.lang.Override public java.lang.String getError() { java.lang.Object ref = error_; if (ref instanceof java.lang.String) { return (java.lang.String) ref; } else { com.google.protobuf.ByteString bs = (com.google.protobuf.ByteString) ref; java.lang.String s = bs.toStringUtf8(); if (bs.isValidUtf8()) { error_ = s; } return s; } } /** *
     * 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.
     * 
* * optional string error = 1; * @return The bytes for error. */ @java.lang.Override public com.google.protobuf.ByteString getErrorBytes() { java.lang.Object ref = error_; if (ref instanceof java.lang.String) { com.google.protobuf.ByteString b = com.google.protobuf.ByteString.copyFromUtf8( (java.lang.String) ref); error_ = b; return b; } else { return (com.google.protobuf.ByteString) ref; } } public static final int SUPPORTED_FEATURES_FIELD_NUMBER = 2; private long supportedFeatures_ = 0L; /** *
     * A bitmask of supported features that the code generator supports.
     * This is a bitwise "or" of values from the Feature enum.
     * 
* * optional uint64 supported_features = 2; * @return Whether the supportedFeatures field is set. */ @java.lang.Override public boolean hasSupportedFeatures() { return ((bitField0_ & 0x00000002) != 0); } /** *
     * A bitmask of supported features that the code generator supports.
     * This is a bitwise "or" of values from the Feature enum.
     * 
* * optional uint64 supported_features = 2; * @return The supportedFeatures. */ @java.lang.Override public long getSupportedFeatures() { return supportedFeatures_; } public static final int FILE_FIELD_NUMBER = 15; @SuppressWarnings("serial") private java.util.List file_; /** * repeated .google.protobuf.compiler.CodeGeneratorResponse.File file = 15; */ @java.lang.Override public java.util.List getFileList() { return file_; } /** * repeated .google.protobuf.compiler.CodeGeneratorResponse.File file = 15; */ @java.lang.Override public java.util.List getFileOrBuilderList() { return file_; } /** * repeated .google.protobuf.compiler.CodeGeneratorResponse.File file = 15; */ @java.lang.Override public int getFileCount() { return file_.size(); } /** * repeated .google.protobuf.compiler.CodeGeneratorResponse.File file = 15; */ @java.lang.Override public com.google.protobuf.compiler.PluginProtos.CodeGeneratorResponse.File getFile(int index) { return file_.get(index); } /** * repeated .google.protobuf.compiler.CodeGeneratorResponse.File file = 15; */ @java.lang.Override public com.google.protobuf.compiler.PluginProtos.CodeGeneratorResponse.FileOrBuilder getFileOrBuilder( int index) { return file_.get(index); } private byte memoizedIsInitialized = -1; @java.lang.Override public final boolean isInitialized() { byte isInitialized = memoizedIsInitialized; if (isInitialized == 1) return true; if (isInitialized == 0) return false; memoizedIsInitialized = 1; return true; } @java.lang.Override public void writeTo(com.google.protobuf.CodedOutputStream output) throws java.io.IOException { if (((bitField0_ & 0x00000001) != 0)) { com.google.protobuf.GeneratedMessageV3.writeString(output, 1, error_); } if (((bitField0_ & 0x00000002) != 0)) { output.writeUInt64(2, supportedFeatures_); } for (int i = 0; i < file_.size(); i++) { output.writeMessage(15, file_.get(i)); } getUnknownFields().writeTo(output); } @java.lang.Override public int getSerializedSize() { int size = memoizedSize; if (size != -1) return size; size = 0; if (((bitField0_ & 0x00000001) != 0)) { size += com.google.protobuf.GeneratedMessageV3.computeStringSize(1, error_); } if (((bitField0_ & 0x00000002) != 0)) { size += com.google.protobuf.CodedOutputStream .computeUInt64Size(2, supportedFeatures_); } for (int i = 0; i < file_.size(); i++) { size += com.google.protobuf.CodedOutputStream .computeMessageSize(15, file_.get(i)); } size += getUnknownFields().getSerializedSize(); memoizedSize = size; return size; } @java.lang.Override public boolean equals(final java.lang.Object obj) { if (obj == this) { return true; } if (!(obj instanceof com.google.protobuf.compiler.PluginProtos.CodeGeneratorResponse)) { return super.equals(obj); } com.google.protobuf.compiler.PluginProtos.CodeGeneratorResponse other = (com.google.protobuf.compiler.PluginProtos.CodeGeneratorResponse) obj; if (hasError() != other.hasError()) return false; if (hasError()) { if (!getError() .equals(other.getError())) return false; } if (hasSupportedFeatures() != other.hasSupportedFeatures()) return false; if (hasSupportedFeatures()) { if (getSupportedFeatures() != other.getSupportedFeatures()) return false; } if (!getFileList() .equals(other.getFileList())) return false; if (!getUnknownFields().equals(other.getUnknownFields())) return false; return true; } @java.lang.Override public int hashCode() { if (memoizedHashCode != 0) { return memoizedHashCode; } int hash = 41; hash = (19 * hash) + getDescriptor().hashCode(); if (hasError()) { hash = (37 * hash) + ERROR_FIELD_NUMBER; hash = (53 * hash) + getError().hashCode(); } if (hasSupportedFeatures()) { hash = (37 * hash) + SUPPORTED_FEATURES_FIELD_NUMBER; hash = (53 * hash) + com.google.protobuf.Internal.hashLong( getSupportedFeatures()); } if (getFileCount() > 0) { hash = (37 * hash) + FILE_FIELD_NUMBER; hash = (53 * hash) + getFileList().hashCode(); } hash = (29 * hash) + getUnknownFields().hashCode(); memoizedHashCode = hash; return hash; } public static com.google.protobuf.compiler.PluginProtos.CodeGeneratorResponse parseFrom( java.nio.ByteBuffer data) throws com.google.protobuf.InvalidProtocolBufferException { return PARSER.parseFrom(data); } public static com.google.protobuf.compiler.PluginProtos.CodeGeneratorResponse parseFrom( java.nio.ByteBuffer data, com.google.protobuf.ExtensionRegistryLite extensionRegistry) throws com.google.protobuf.InvalidProtocolBufferException { return PARSER.parseFrom(data, extensionRegistry); } public static com.google.protobuf.compiler.PluginProtos.CodeGeneratorResponse parseFrom( com.google.protobuf.ByteString data) throws com.google.protobuf.InvalidProtocolBufferException { return PARSER.parseFrom(data); } public static com.google.protobuf.compiler.PluginProtos.CodeGeneratorResponse parseFrom( com.google.protobuf.ByteString data, com.google.protobuf.ExtensionRegistryLite extensionRegistry) throws com.google.protobuf.InvalidProtocolBufferException { return PARSER.parseFrom(data, extensionRegistry); } public static com.google.protobuf.compiler.PluginProtos.CodeGeneratorResponse parseFrom(byte[] data) throws com.google.protobuf.InvalidProtocolBufferException { return PARSER.parseFrom(data); } public static com.google.protobuf.compiler.PluginProtos.CodeGeneratorResponse parseFrom( byte[] data, com.google.protobuf.ExtensionRegistryLite extensionRegistry) throws com.google.protobuf.InvalidProtocolBufferException { return PARSER.parseFrom(data, extensionRegistry); } public static com.google.protobuf.compiler.PluginProtos.CodeGeneratorResponse parseFrom(java.io.InputStream input) throws java.io.IOException { return com.google.protobuf.GeneratedMessageV3 .parseWithIOException(PARSER, input); } public static com.google.protobuf.compiler.PluginProtos.CodeGeneratorResponse parseFrom( java.io.InputStream input, com.google.protobuf.ExtensionRegistryLite extensionRegistry) throws java.io.IOException { return com.google.protobuf.GeneratedMessageV3 .parseWithIOException(PARSER, input, extensionRegistry); } public static com.google.protobuf.compiler.PluginProtos.CodeGeneratorResponse parseDelimitedFrom(java.io.InputStream input) throws java.io.IOException { return com.google.protobuf.GeneratedMessageV3 .parseDelimitedWithIOException(PARSER, input); } public static com.google.protobuf.compiler.PluginProtos.CodeGeneratorResponse parseDelimitedFrom( java.io.InputStream input, com.google.protobuf.ExtensionRegistryLite extensionRegistry) throws java.io.IOException { return com.google.protobuf.GeneratedMessageV3 .parseDelimitedWithIOException(PARSER, input, extensionRegistry); } public static com.google.protobuf.compiler.PluginProtos.CodeGeneratorResponse parseFrom( com.google.protobuf.CodedInputStream input) throws java.io.IOException { return com.google.protobuf.GeneratedMessageV3 .parseWithIOException(PARSER, input); } public static com.google.protobuf.compiler.PluginProtos.CodeGeneratorResponse parseFrom( com.google.protobuf.CodedInputStream input, com.google.protobuf.ExtensionRegistryLite extensionRegistry) throws java.io.IOException { return com.google.protobuf.GeneratedMessageV3 .parseWithIOException(PARSER, input, extensionRegistry); } @java.lang.Override public Builder newBuilderForType() { return newBuilder(); } public static Builder newBuilder() { return DEFAULT_INSTANCE.toBuilder(); } public static Builder newBuilder(com.google.protobuf.compiler.PluginProtos.CodeGeneratorResponse prototype) { return DEFAULT_INSTANCE.toBuilder().mergeFrom(prototype); } @java.lang.Override public Builder toBuilder() { return this == DEFAULT_INSTANCE ? new Builder() : new Builder().mergeFrom(this); } @java.lang.Override protected Builder newBuilderForType( com.google.protobuf.GeneratedMessageV3.BuilderParent parent) { Builder builder = new Builder(parent); return builder; } /** *
     * The plugin writes an encoded CodeGeneratorResponse to stdout.
     * 
* * Protobuf type {@code google.protobuf.compiler.CodeGeneratorResponse} */ public static final class Builder extends com.google.protobuf.GeneratedMessageV3.Builder implements // @@protoc_insertion_point(builder_implements:google.protobuf.compiler.CodeGeneratorResponse) com.google.protobuf.compiler.PluginProtos.CodeGeneratorResponseOrBuilder { public static final com.google.protobuf.Descriptors.Descriptor getDescriptor() { return com.google.protobuf.compiler.PluginProtos.internal_static_google_protobuf_compiler_CodeGeneratorResponse_descriptor; } @java.lang.Override protected com.google.protobuf.GeneratedMessageV3.FieldAccessorTable internalGetFieldAccessorTable() { return com.google.protobuf.compiler.PluginProtos.internal_static_google_protobuf_compiler_CodeGeneratorResponse_fieldAccessorTable .ensureFieldAccessorsInitialized( com.google.protobuf.compiler.PluginProtos.CodeGeneratorResponse.class, com.google.protobuf.compiler.PluginProtos.CodeGeneratorResponse.Builder.class); } // Construct using com.google.protobuf.compiler.PluginProtos.CodeGeneratorResponse.newBuilder() private Builder() { } private Builder( com.google.protobuf.GeneratedMessageV3.BuilderParent parent) { super(parent); } @java.lang.Override public Builder clear() { super.clear(); bitField0_ = 0; error_ = ""; supportedFeatures_ = 0L; if (fileBuilder_ == null) { file_ = java.util.Collections.emptyList(); } else { file_ = null; fileBuilder_.clear(); } bitField0_ = (bitField0_ & ~0x00000004); return this; } @java.lang.Override public com.google.protobuf.Descriptors.Descriptor getDescriptorForType() { return com.google.protobuf.compiler.PluginProtos.internal_static_google_protobuf_compiler_CodeGeneratorResponse_descriptor; } @java.lang.Override public com.google.protobuf.compiler.PluginProtos.CodeGeneratorResponse getDefaultInstanceForType() { return com.google.protobuf.compiler.PluginProtos.CodeGeneratorResponse.getDefaultInstance(); } @java.lang.Override public com.google.protobuf.compiler.PluginProtos.CodeGeneratorResponse build() { com.google.protobuf.compiler.PluginProtos.CodeGeneratorResponse result = buildPartial(); if (!result.isInitialized()) { throw newUninitializedMessageException(result); } return result; } @java.lang.Override public com.google.protobuf.compiler.PluginProtos.CodeGeneratorResponse buildPartial() { com.google.protobuf.compiler.PluginProtos.CodeGeneratorResponse result = new com.google.protobuf.compiler.PluginProtos.CodeGeneratorResponse(this); buildPartialRepeatedFields(result); if (bitField0_ != 0) { buildPartial0(result); } onBuilt(); return result; } private void buildPartialRepeatedFields(com.google.protobuf.compiler.PluginProtos.CodeGeneratorResponse result) { if (fileBuilder_ == null) { if (((bitField0_ & 0x00000004) != 0)) { file_ = java.util.Collections.unmodifiableList(file_); bitField0_ = (bitField0_ & ~0x00000004); } result.file_ = file_; } else { result.file_ = fileBuilder_.build(); } } private void buildPartial0(com.google.protobuf.compiler.PluginProtos.CodeGeneratorResponse result) { int from_bitField0_ = bitField0_; int to_bitField0_ = 0; if (((from_bitField0_ & 0x00000001) != 0)) { result.error_ = error_; to_bitField0_ |= 0x00000001; } if (((from_bitField0_ & 0x00000002) != 0)) { result.supportedFeatures_ = supportedFeatures_; to_bitField0_ |= 0x00000002; } result.bitField0_ |= to_bitField0_; } @java.lang.Override public Builder clone() { return super.clone(); } @java.lang.Override public Builder setField( com.google.protobuf.Descriptors.FieldDescriptor field, java.lang.Object value) { return super.setField(field, value); } @java.lang.Override public Builder clearField( com.google.protobuf.Descriptors.FieldDescriptor field) { return super.clearField(field); } @java.lang.Override public Builder clearOneof( com.google.protobuf.Descriptors.OneofDescriptor oneof) { return super.clearOneof(oneof); } @java.lang.Override public Builder setRepeatedField( com.google.protobuf.Descriptors.FieldDescriptor field, int index, java.lang.Object value) { return super.setRepeatedField(field, index, value); } @java.lang.Override public Builder addRepeatedField( com.google.protobuf.Descriptors.FieldDescriptor field, java.lang.Object value) { return super.addRepeatedField(field, value); } @java.lang.Override public Builder mergeFrom(com.google.protobuf.Message other) { if (other instanceof com.google.protobuf.compiler.PluginProtos.CodeGeneratorResponse) { return mergeFrom((com.google.protobuf.compiler.PluginProtos.CodeGeneratorResponse)other); } else { super.mergeFrom(other); return this; } } public Builder mergeFrom(com.google.protobuf.compiler.PluginProtos.CodeGeneratorResponse other) { if (other == com.google.protobuf.compiler.PluginProtos.CodeGeneratorResponse.getDefaultInstance()) return this; if (other.hasError()) { error_ = other.error_; bitField0_ |= 0x00000001; onChanged(); } if (other.hasSupportedFeatures()) { setSupportedFeatures(other.getSupportedFeatures()); } if (fileBuilder_ == null) { if (!other.file_.isEmpty()) { if (file_.isEmpty()) { file_ = other.file_; bitField0_ = (bitField0_ & ~0x00000004); } else { ensureFileIsMutable(); file_.addAll(other.file_); } onChanged(); } } else { if (!other.file_.isEmpty()) { if (fileBuilder_.isEmpty()) { fileBuilder_.dispose(); fileBuilder_ = null; file_ = other.file_; bitField0_ = (bitField0_ & ~0x00000004); fileBuilder_ = com.google.protobuf.GeneratedMessageV3.alwaysUseFieldBuilders ? getFileFieldBuilder() : null; } else { fileBuilder_.addAllMessages(other.file_); } } } this.mergeUnknownFields(other.getUnknownFields()); onChanged(); return this; } @java.lang.Override public final boolean isInitialized() { return true; } @java.lang.Override public Builder mergeFrom( com.google.protobuf.CodedInputStream input, com.google.protobuf.ExtensionRegistryLite extensionRegistry) throws java.io.IOException { if (extensionRegistry == null) { throw new java.lang.NullPointerException(); } try { boolean done = false; while (!done) { int tag = input.readTag(); switch (tag) { case 0: done = true; break; case 10: { error_ = input.readBytes(); bitField0_ |= 0x00000001; break; } // case 10 case 16: { supportedFeatures_ = input.readUInt64(); bitField0_ |= 0x00000002; break; } // case 16 case 122: { com.google.protobuf.compiler.PluginProtos.CodeGeneratorResponse.File m = input.readMessage( com.google.protobuf.compiler.PluginProtos.CodeGeneratorResponse.File.PARSER, extensionRegistry); if (fileBuilder_ == null) { ensureFileIsMutable(); file_.add(m); } else { fileBuilder_.addMessage(m); } break; } // case 122 default: { if (!super.parseUnknownField(input, extensionRegistry, tag)) { done = true; // was an endgroup tag } break; } // default: } // switch (tag) } // while (!done) } catch (com.google.protobuf.InvalidProtocolBufferException e) { throw e.unwrapIOException(); } finally { onChanged(); } // finally return this; } private int bitField0_; private java.lang.Object error_ = ""; /** *
       * 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.
       * 
* * optional string error = 1; * @return Whether the error field is set. */ public boolean hasError() { return ((bitField0_ & 0x00000001) != 0); } /** *
       * 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.
       * 
* * optional string error = 1; * @return The error. */ public java.lang.String getError() { java.lang.Object ref = error_; if (!(ref instanceof java.lang.String)) { com.google.protobuf.ByteString bs = (com.google.protobuf.ByteString) ref; java.lang.String s = bs.toStringUtf8(); if (bs.isValidUtf8()) { error_ = s; } return s; } else { return (java.lang.String) ref; } } /** *
       * 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.
       * 
* * optional string error = 1; * @return The bytes for error. */ public com.google.protobuf.ByteString getErrorBytes() { java.lang.Object ref = error_; if (ref instanceof String) { com.google.protobuf.ByteString b = com.google.protobuf.ByteString.copyFromUtf8( (java.lang.String) ref); error_ = b; return b; } else { return (com.google.protobuf.ByteString) ref; } } /** *
       * 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.
       * 
* * optional string error = 1; * @param value The error to set. * @return This builder for chaining. */ public Builder setError( java.lang.String value) { if (value == null) { throw new NullPointerException(); } error_ = value; bitField0_ |= 0x00000001; onChanged(); return this; } /** *
       * 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.
       * 
* * optional string error = 1; * @return This builder for chaining. */ public Builder clearError() { error_ = getDefaultInstance().getError(); bitField0_ = (bitField0_ & ~0x00000001); onChanged(); return this; } /** *
       * 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.
       * 
* * optional string error = 1; * @param value The bytes for error to set. * @return This builder for chaining. */ public Builder setErrorBytes( com.google.protobuf.ByteString value) { if (value == null) { throw new NullPointerException(); } error_ = value; bitField0_ |= 0x00000001; onChanged(); return this; } private long supportedFeatures_ ; /** *
       * A bitmask of supported features that the code generator supports.
       * This is a bitwise "or" of values from the Feature enum.
       * 
* * optional uint64 supported_features = 2; * @return Whether the supportedFeatures field is set. */ @java.lang.Override public boolean hasSupportedFeatures() { return ((bitField0_ & 0x00000002) != 0); } /** *
       * A bitmask of supported features that the code generator supports.
       * This is a bitwise "or" of values from the Feature enum.
       * 
* * optional uint64 supported_features = 2; * @return The supportedFeatures. */ @java.lang.Override public long getSupportedFeatures() { return supportedFeatures_; } /** *
       * A bitmask of supported features that the code generator supports.
       * This is a bitwise "or" of values from the Feature enum.
       * 
* * optional uint64 supported_features = 2; * @param value The supportedFeatures to set. * @return This builder for chaining. */ public Builder setSupportedFeatures(long value) { supportedFeatures_ = value; bitField0_ |= 0x00000002; onChanged(); return this; } /** *
       * A bitmask of supported features that the code generator supports.
       * This is a bitwise "or" of values from the Feature enum.
       * 
* * optional uint64 supported_features = 2; * @return This builder for chaining. */ public Builder clearSupportedFeatures() { bitField0_ = (bitField0_ & ~0x00000002); supportedFeatures_ = 0L; onChanged(); return this; } private java.util.List file_ = java.util.Collections.emptyList(); private void ensureFileIsMutable() { if (!((bitField0_ & 0x00000004) != 0)) { file_ = new java.util.ArrayList(file_); bitField0_ |= 0x00000004; } } private com.google.protobuf.RepeatedFieldBuilderV3< com.google.protobuf.compiler.PluginProtos.CodeGeneratorResponse.File, com.google.protobuf.compiler.PluginProtos.CodeGeneratorResponse.File.Builder, com.google.protobuf.compiler.PluginProtos.CodeGeneratorResponse.FileOrBuilder> fileBuilder_; /** * repeated .google.protobuf.compiler.CodeGeneratorResponse.File file = 15; */ public java.util.List getFileList() { if (fileBuilder_ == null) { return java.util.Collections.unmodifiableList(file_); } else { return fileBuilder_.getMessageList(); } } /** * repeated .google.protobuf.compiler.CodeGeneratorResponse.File file = 15; */ public int getFileCount() { if (fileBuilder_ == null) { return file_.size(); } else { return fileBuilder_.getCount(); } } /** * repeated .google.protobuf.compiler.CodeGeneratorResponse.File file = 15; */ public com.google.protobuf.compiler.PluginProtos.CodeGeneratorResponse.File getFile(int index) { if (fileBuilder_ == null) { return file_.get(index); } else { return fileBuilder_.getMessage(index); } } /** * repeated .google.protobuf.compiler.CodeGeneratorResponse.File file = 15; */ public Builder setFile( int index, com.google.protobuf.compiler.PluginProtos.CodeGeneratorResponse.File value) { if (fileBuilder_ == null) { if (value == null) { throw new NullPointerException(); } ensureFileIsMutable(); file_.set(index, value); onChanged(); } else { fileBuilder_.setMessage(index, value); } return this; } /** * repeated .google.protobuf.compiler.CodeGeneratorResponse.File file = 15; */ public Builder setFile( int index, com.google.protobuf.compiler.PluginProtos.CodeGeneratorResponse.File.Builder builderForValue) { if (fileBuilder_ == null) { ensureFileIsMutable(); file_.set(index, builderForValue.build()); onChanged(); } else { fileBuilder_.setMessage(index, builderForValue.build()); } return this; } /** * repeated .google.protobuf.compiler.CodeGeneratorResponse.File file = 15; */ public Builder addFile(com.google.protobuf.compiler.PluginProtos.CodeGeneratorResponse.File value) { if (fileBuilder_ == null) { if (value == null) { throw new NullPointerException(); } ensureFileIsMutable(); file_.add(value); onChanged(); } else { fileBuilder_.addMessage(value); } return this; } /** * repeated .google.protobuf.compiler.CodeGeneratorResponse.File file = 15; */ public Builder addFile( int index, com.google.protobuf.compiler.PluginProtos.CodeGeneratorResponse.File value) { if (fileBuilder_ == null) { if (value == null) { throw new NullPointerException(); } ensureFileIsMutable(); file_.add(index, value); onChanged(); } else { fileBuilder_.addMessage(index, value); } return this; } /** * repeated .google.protobuf.compiler.CodeGeneratorResponse.File file = 15; */ public Builder addFile( com.google.protobuf.compiler.PluginProtos.CodeGeneratorResponse.File.Builder builderForValue) { if (fileBuilder_ == null) { ensureFileIsMutable(); file_.add(builderForValue.build()); onChanged(); } else { fileBuilder_.addMessage(builderForValue.build()); } return this; } /** * repeated .google.protobuf.compiler.CodeGeneratorResponse.File file = 15; */ public Builder addFile( int index, com.google.protobuf.compiler.PluginProtos.CodeGeneratorResponse.File.Builder builderForValue) { if (fileBuilder_ == null) { ensureFileIsMutable(); file_.add(index, builderForValue.build()); onChanged(); } else { fileBuilder_.addMessage(index, builderForValue.build()); } return this; } /** * repeated .google.protobuf.compiler.CodeGeneratorResponse.File file = 15; */ public Builder addAllFile( java.lang.Iterable values) { if (fileBuilder_ == null) { ensureFileIsMutable(); com.google.protobuf.AbstractMessageLite.Builder.addAll( values, file_); onChanged(); } else { fileBuilder_.addAllMessages(values); } return this; } /** * repeated .google.protobuf.compiler.CodeGeneratorResponse.File file = 15; */ public Builder clearFile() { if (fileBuilder_ == null) { file_ = java.util.Collections.emptyList(); bitField0_ = (bitField0_ & ~0x00000004); onChanged(); } else { fileBuilder_.clear(); } return this; } /** * repeated .google.protobuf.compiler.CodeGeneratorResponse.File file = 15; */ public Builder removeFile(int index) { if (fileBuilder_ == null) { ensureFileIsMutable(); file_.remove(index); onChanged(); } else { fileBuilder_.remove(index); } return this; } /** * repeated .google.protobuf.compiler.CodeGeneratorResponse.File file = 15; */ public com.google.protobuf.compiler.PluginProtos.CodeGeneratorResponse.File.Builder getFileBuilder( int index) { return getFileFieldBuilder().getBuilder(index); } /** * repeated .google.protobuf.compiler.CodeGeneratorResponse.File file = 15; */ public com.google.protobuf.compiler.PluginProtos.CodeGeneratorResponse.FileOrBuilder getFileOrBuilder( int index) { if (fileBuilder_ == null) { return file_.get(index); } else { return fileBuilder_.getMessageOrBuilder(index); } } /** * repeated .google.protobuf.compiler.CodeGeneratorResponse.File file = 15; */ public java.util.List getFileOrBuilderList() { if (fileBuilder_ != null) { return fileBuilder_.getMessageOrBuilderList(); } else { return java.util.Collections.unmodifiableList(file_); } } /** * repeated .google.protobuf.compiler.CodeGeneratorResponse.File file = 15; */ public com.google.protobuf.compiler.PluginProtos.CodeGeneratorResponse.File.Builder addFileBuilder() { return getFileFieldBuilder().addBuilder( com.google.protobuf.compiler.PluginProtos.CodeGeneratorResponse.File.getDefaultInstance()); } /** * repeated .google.protobuf.compiler.CodeGeneratorResponse.File file = 15; */ public com.google.protobuf.compiler.PluginProtos.CodeGeneratorResponse.File.Builder addFileBuilder( int index) { return getFileFieldBuilder().addBuilder( index, com.google.protobuf.compiler.PluginProtos.CodeGeneratorResponse.File.getDefaultInstance()); } /** * repeated .google.protobuf.compiler.CodeGeneratorResponse.File file = 15; */ public java.util.List getFileBuilderList() { return getFileFieldBuilder().getBuilderList(); } private com.google.protobuf.RepeatedFieldBuilderV3< com.google.protobuf.compiler.PluginProtos.CodeGeneratorResponse.File, com.google.protobuf.compiler.PluginProtos.CodeGeneratorResponse.File.Builder, com.google.protobuf.compiler.PluginProtos.CodeGeneratorResponse.FileOrBuilder> getFileFieldBuilder() { if (fileBuilder_ == null) { fileBuilder_ = new com.google.protobuf.RepeatedFieldBuilderV3< com.google.protobuf.compiler.PluginProtos.CodeGeneratorResponse.File, com.google.protobuf.compiler.PluginProtos.CodeGeneratorResponse.File.Builder, com.google.protobuf.compiler.PluginProtos.CodeGeneratorResponse.FileOrBuilder>( file_, ((bitField0_ & 0x00000004) != 0), getParentForChildren(), isClean()); file_ = null; } return fileBuilder_; } @java.lang.Override public final Builder setUnknownFields( final com.google.protobuf.UnknownFieldSet unknownFields) { return super.setUnknownFields(unknownFields); } @java.lang.Override public final Builder mergeUnknownFields( final com.google.protobuf.UnknownFieldSet unknownFields) { return super.mergeUnknownFields(unknownFields); } // @@protoc_insertion_point(builder_scope:google.protobuf.compiler.CodeGeneratorResponse) } // @@protoc_insertion_point(class_scope:google.protobuf.compiler.CodeGeneratorResponse) private static final com.google.protobuf.compiler.PluginProtos.CodeGeneratorResponse DEFAULT_INSTANCE; static { DEFAULT_INSTANCE = new com.google.protobuf.compiler.PluginProtos.CodeGeneratorResponse(); } public static com.google.protobuf.compiler.PluginProtos.CodeGeneratorResponse getDefaultInstance() { return DEFAULT_INSTANCE; } @java.lang.Deprecated public static final com.google.protobuf.Parser PARSER = new com.google.protobuf.AbstractParser() { @java.lang.Override public CodeGeneratorResponse parsePartialFrom( com.google.protobuf.CodedInputStream input, com.google.protobuf.ExtensionRegistryLite extensionRegistry) throws com.google.protobuf.InvalidProtocolBufferException { Builder builder = newBuilder(); try { builder.mergeFrom(input, extensionRegistry); } catch (com.google.protobuf.InvalidProtocolBufferException e) { throw e.setUnfinishedMessage(builder.buildPartial()); } catch (com.google.protobuf.UninitializedMessageException e) { throw e.asInvalidProtocolBufferException().setUnfinishedMessage(builder.buildPartial()); } catch (java.io.IOException e) { throw new com.google.protobuf.InvalidProtocolBufferException(e) .setUnfinishedMessage(builder.buildPartial()); } return builder.buildPartial(); } }; public static com.google.protobuf.Parser parser() { return PARSER; } @java.lang.Override public com.google.protobuf.Parser getParserForType() { return PARSER; } @java.lang.Override public com.google.protobuf.compiler.PluginProtos.CodeGeneratorResponse getDefaultInstanceForType() { return DEFAULT_INSTANCE; } } private static final com.google.protobuf.Descriptors.Descriptor internal_static_google_protobuf_compiler_Version_descriptor; private static final com.google.protobuf.GeneratedMessageV3.FieldAccessorTable internal_static_google_protobuf_compiler_Version_fieldAccessorTable; private static final com.google.protobuf.Descriptors.Descriptor internal_static_google_protobuf_compiler_CodeGeneratorRequest_descriptor; private static final com.google.protobuf.GeneratedMessageV3.FieldAccessorTable internal_static_google_protobuf_compiler_CodeGeneratorRequest_fieldAccessorTable; private static final com.google.protobuf.Descriptors.Descriptor internal_static_google_protobuf_compiler_CodeGeneratorResponse_descriptor; private static final com.google.protobuf.GeneratedMessageV3.FieldAccessorTable internal_static_google_protobuf_compiler_CodeGeneratorResponse_fieldAccessorTable; private static final com.google.protobuf.Descriptors.Descriptor internal_static_google_protobuf_compiler_CodeGeneratorResponse_File_descriptor; private static final com.google.protobuf.GeneratedMessageV3.FieldAccessorTable internal_static_google_protobuf_compiler_CodeGeneratorResponse_File_fieldAccessorTable; public static com.google.protobuf.Descriptors.FileDescriptor getDescriptor() { return descriptor; } private static com.google.protobuf.Descriptors.FileDescriptor descriptor; static { java.lang.String[] descriptorData = { "\n%google/protobuf/compiler/plugin.proto\022" + "\030google.protobuf.compiler\032 google/protob" + "uf/descriptor.proto\"F\n\007Version\022\r\n\005major\030" + "\001 \001(\005\022\r\n\005minor\030\002 \001(\005\022\r\n\005patch\030\003 \001(\005\022\016\n\006s" + "uffix\030\004 \001(\t\"\272\001\n\024CodeGeneratorRequest\022\030\n\020" + "file_to_generate\030\001 \003(\t\022\021\n\tparameter\030\002 \001(" + "\t\0228\n\nproto_file\030\017 \003(\0132$.google.protobuf." + "FileDescriptorProto\022;\n\020compiler_version\030" + "\003 \001(\0132!.google.protobuf.compiler.Version" + "\"\301\002\n\025CodeGeneratorResponse\022\r\n\005error\030\001 \001(" + "\t\022\032\n\022supported_features\030\002 \001(\004\022B\n\004file\030\017 " + "\003(\01324.google.protobuf.compiler.CodeGener" + "atorResponse.File\032\177\n\004File\022\014\n\004name\030\001 \001(\t\022" + "\027\n\017insertion_point\030\002 \001(\t\022\017\n\007content\030\017 \001(" + "\t\022?\n\023generated_code_info\030\020 \001(\0132\".google." + "protobuf.GeneratedCodeInfo\"8\n\007Feature\022\020\n" + "\014FEATURE_NONE\020\000\022\033\n\027FEATURE_PROTO3_OPTION" + "AL\020\001BW\n\034com.google.protobuf.compilerB\014Pl" + "uginProtosZ)google.golang.org/protobuf/t" + "ypes/pluginpb" }; descriptor = com.google.protobuf.Descriptors.FileDescriptor .internalBuildGeneratedFileFrom(descriptorData, new com.google.protobuf.Descriptors.FileDescriptor[] { com.google.protobuf.DescriptorProtos.getDescriptor(), }); internal_static_google_protobuf_compiler_Version_descriptor = getDescriptor().getMessageTypes().get(0); internal_static_google_protobuf_compiler_Version_fieldAccessorTable = new com.google.protobuf.GeneratedMessageV3.FieldAccessorTable( internal_static_google_protobuf_compiler_Version_descriptor, new java.lang.String[] { "Major", "Minor", "Patch", "Suffix", }); internal_static_google_protobuf_compiler_CodeGeneratorRequest_descriptor = getDescriptor().getMessageTypes().get(1); internal_static_google_protobuf_compiler_CodeGeneratorRequest_fieldAccessorTable = new com.google.protobuf.GeneratedMessageV3.FieldAccessorTable( internal_static_google_protobuf_compiler_CodeGeneratorRequest_descriptor, new java.lang.String[] { "FileToGenerate", "Parameter", "ProtoFile", "CompilerVersion", }); internal_static_google_protobuf_compiler_CodeGeneratorResponse_descriptor = getDescriptor().getMessageTypes().get(2); internal_static_google_protobuf_compiler_CodeGeneratorResponse_fieldAccessorTable = new com.google.protobuf.GeneratedMessageV3.FieldAccessorTable( internal_static_google_protobuf_compiler_CodeGeneratorResponse_descriptor, new java.lang.String[] { "Error", "SupportedFeatures", "File", }); internal_static_google_protobuf_compiler_CodeGeneratorResponse_File_descriptor = internal_static_google_protobuf_compiler_CodeGeneratorResponse_descriptor.getNestedTypes().get(0); internal_static_google_protobuf_compiler_CodeGeneratorResponse_File_fieldAccessorTable = new com.google.protobuf.GeneratedMessageV3.FieldAccessorTable( internal_static_google_protobuf_compiler_CodeGeneratorResponse_File_descriptor, new java.lang.String[] { "Name", "InsertionPoint", "Content", "GeneratedCodeInfo", }); com.google.protobuf.DescriptorProtos.getDescriptor(); } // @@protoc_insertion_point(outer_class_scope) }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy