Common.java

// Generated by the protocol buffer compiler.  DO NOT EDIT!
// source: common.proto

package org.apache.calcite.avatica.proto;

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

  public static void registerAllExtensions(
      com.google.protobuf.ExtensionRegistry registry) {
    registerAllExtensions(
        (com.google.protobuf.ExtensionRegistryLite) registry);
  }
  /**
   * <pre>
   * Has to be consistent with Meta.StatementType
   * </pre>
   *
   * Protobuf enum {@code StatementType}
   */
  public enum StatementType
      implements com.google.protobuf.ProtocolMessageEnum {
    /**
     * <code>SELECT = 0;</code>
     */
    SELECT(0),
    /**
     * <code>INSERT = 1;</code>
     */
    INSERT(1),
    /**
     * <code>UPDATE = 2;</code>
     */
    UPDATE(2),
    /**
     * <code>DELETE = 3;</code>
     */
    DELETE(3),
    /**
     * <code>UPSERT = 4;</code>
     */
    UPSERT(4),
    /**
     * <code>MERGE = 5;</code>
     */
    MERGE(5),
    /**
     * <code>OTHER_DML = 6;</code>
     */
    OTHER_DML(6),
    /**
     * <code>CREATE = 7;</code>
     */
    CREATE(7),
    /**
     * <code>DROP = 8;</code>
     */
    DROP(8),
    /**
     * <code>ALTER = 9;</code>
     */
    ALTER(9),
    /**
     * <code>OTHER_DDL = 10;</code>
     */
    OTHER_DDL(10),
    /**
     * <code>CALL = 11;</code>
     */
    CALL(11),
    UNRECOGNIZED(-1),
    ;

    /**
     * <code>SELECT = 0;</code>
     */
    public static final int SELECT_VALUE = 0;
    /**
     * <code>INSERT = 1;</code>
     */
    public static final int INSERT_VALUE = 1;
    /**
     * <code>UPDATE = 2;</code>
     */
    public static final int UPDATE_VALUE = 2;
    /**
     * <code>DELETE = 3;</code>
     */
    public static final int DELETE_VALUE = 3;
    /**
     * <code>UPSERT = 4;</code>
     */
    public static final int UPSERT_VALUE = 4;
    /**
     * <code>MERGE = 5;</code>
     */
    public static final int MERGE_VALUE = 5;
    /**
     * <code>OTHER_DML = 6;</code>
     */
    public static final int OTHER_DML_VALUE = 6;
    /**
     * <code>CREATE = 7;</code>
     */
    public static final int CREATE_VALUE = 7;
    /**
     * <code>DROP = 8;</code>
     */
    public static final int DROP_VALUE = 8;
    /**
     * <code>ALTER = 9;</code>
     */
    public static final int ALTER_VALUE = 9;
    /**
     * <code>OTHER_DDL = 10;</code>
     */
    public static final int OTHER_DDL_VALUE = 10;
    /**
     * <code>CALL = 11;</code>
     */
    public static final int CALL_VALUE = 11;


    public final int getNumber() {
      if (this == UNRECOGNIZED) {
        throw new java.lang.IllegalArgumentException(
            "Can't get the number of an unknown enum value.");
      }
      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 StatementType 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 StatementType forNumber(int value) {
      switch (value) {
        case 0: return SELECT;
        case 1: return INSERT;
        case 2: return UPDATE;
        case 3: return DELETE;
        case 4: return UPSERT;
        case 5: return MERGE;
        case 6: return OTHER_DML;
        case 7: return CREATE;
        case 8: return DROP;
        case 9: return ALTER;
        case 10: return OTHER_DDL;
        case 11: return CALL;
        default: return null;
      }
    }

    public static com.google.protobuf.Internal.EnumLiteMap<StatementType>
        internalGetValueMap() {
      return internalValueMap;
    }
    private static final com.google.protobuf.Internal.EnumLiteMap<
        StatementType> internalValueMap =
          new com.google.protobuf.Internal.EnumLiteMap<StatementType>() {
            public StatementType findValueByNumber(int number) {
              return StatementType.forNumber(number);
            }
          };

    public final com.google.protobuf.Descriptors.EnumValueDescriptor
        getValueDescriptor() {
      if (this == UNRECOGNIZED) {
        throw new java.lang.IllegalStateException(
            "Can't get the descriptor of an unrecognized enum value.");
      }
      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 org.apache.calcite.avatica.proto.Common.getDescriptor().getEnumTypes().get(0);
    }

    private static final StatementType[] VALUES = values();

    public static StatementType valueOf(
        com.google.protobuf.Descriptors.EnumValueDescriptor desc) {
      if (desc.getType() != getDescriptor()) {
        throw new java.lang.IllegalArgumentException(
          "EnumValueDescriptor is not for this type.");
      }
      if (desc.getIndex() == -1) {
        return UNRECOGNIZED;
      }
      return VALUES[desc.getIndex()];
    }

    private final int value;

    private StatementType(int value) {
      this.value = value;
    }

    // @@protoc_insertion_point(enum_scope:StatementType)
  }

  /**
   * Protobuf enum {@code Rep}
   */
  public enum Rep
      implements com.google.protobuf.ProtocolMessageEnum {
    /**
     * <code>PRIMITIVE_BOOLEAN = 0;</code>
     */
    PRIMITIVE_BOOLEAN(0),
    /**
     * <code>PRIMITIVE_BYTE = 1;</code>
     */
    PRIMITIVE_BYTE(1),
    /**
     * <code>PRIMITIVE_CHAR = 2;</code>
     */
    PRIMITIVE_CHAR(2),
    /**
     * <code>PRIMITIVE_SHORT = 3;</code>
     */
    PRIMITIVE_SHORT(3),
    /**
     * <code>PRIMITIVE_INT = 4;</code>
     */
    PRIMITIVE_INT(4),
    /**
     * <code>PRIMITIVE_LONG = 5;</code>
     */
    PRIMITIVE_LONG(5),
    /**
     * <code>PRIMITIVE_FLOAT = 6;</code>
     */
    PRIMITIVE_FLOAT(6),
    /**
     * <code>PRIMITIVE_DOUBLE = 7;</code>
     */
    PRIMITIVE_DOUBLE(7),
    /**
     * <code>BOOLEAN = 8;</code>
     */
    BOOLEAN(8),
    /**
     * <code>BYTE = 9;</code>
     */
    BYTE(9),
    /**
     * <code>CHARACTER = 10;</code>
     */
    CHARACTER(10),
    /**
     * <code>SHORT = 11;</code>
     */
    SHORT(11),
    /**
     * <code>INTEGER = 12;</code>
     */
    INTEGER(12),
    /**
     * <code>LONG = 13;</code>
     */
    LONG(13),
    /**
     * <code>FLOAT = 14;</code>
     */
    FLOAT(14),
    /**
     * <code>DOUBLE = 15;</code>
     */
    DOUBLE(15),
    /**
     * <code>BIG_INTEGER = 25;</code>
     */
    BIG_INTEGER(25),
    /**
     * <code>BIG_DECIMAL = 26;</code>
     */
    BIG_DECIMAL(26),
    /**
     * <code>JAVA_SQL_TIME = 16;</code>
     */
    JAVA_SQL_TIME(16),
    /**
     * <code>JAVA_SQL_TIMESTAMP = 17;</code>
     */
    JAVA_SQL_TIMESTAMP(17),
    /**
     * <code>JAVA_SQL_DATE = 18;</code>
     */
    JAVA_SQL_DATE(18),
    /**
     * <code>JAVA_UTIL_DATE = 19;</code>
     */
    JAVA_UTIL_DATE(19),
    /**
     * <code>BYTE_STRING = 20;</code>
     */
    BYTE_STRING(20),
    /**
     * <code>STRING = 21;</code>
     */
    STRING(21),
    /**
     * <code>NUMBER = 22;</code>
     */
    NUMBER(22),
    /**
     * <code>OBJECT = 23;</code>
     */
    OBJECT(23),
    /**
     * <code>NULL = 24;</code>
     */
    NULL(24),
    /**
     * <code>ARRAY = 27;</code>
     */
    ARRAY(27),
    /**
     * <code>STRUCT = 28;</code>
     */
    STRUCT(28),
    /**
     * <code>MULTISET = 29;</code>
     */
    MULTISET(29),
    UNRECOGNIZED(-1),
    ;

    /**
     * <code>PRIMITIVE_BOOLEAN = 0;</code>
     */
    public static final int PRIMITIVE_BOOLEAN_VALUE = 0;
    /**
     * <code>PRIMITIVE_BYTE = 1;</code>
     */
    public static final int PRIMITIVE_BYTE_VALUE = 1;
    /**
     * <code>PRIMITIVE_CHAR = 2;</code>
     */
    public static final int PRIMITIVE_CHAR_VALUE = 2;
    /**
     * <code>PRIMITIVE_SHORT = 3;</code>
     */
    public static final int PRIMITIVE_SHORT_VALUE = 3;
    /**
     * <code>PRIMITIVE_INT = 4;</code>
     */
    public static final int PRIMITIVE_INT_VALUE = 4;
    /**
     * <code>PRIMITIVE_LONG = 5;</code>
     */
    public static final int PRIMITIVE_LONG_VALUE = 5;
    /**
     * <code>PRIMITIVE_FLOAT = 6;</code>
     */
    public static final int PRIMITIVE_FLOAT_VALUE = 6;
    /**
     * <code>PRIMITIVE_DOUBLE = 7;</code>
     */
    public static final int PRIMITIVE_DOUBLE_VALUE = 7;
    /**
     * <code>BOOLEAN = 8;</code>
     */
    public static final int BOOLEAN_VALUE = 8;
    /**
     * <code>BYTE = 9;</code>
     */
    public static final int BYTE_VALUE = 9;
    /**
     * <code>CHARACTER = 10;</code>
     */
    public static final int CHARACTER_VALUE = 10;
    /**
     * <code>SHORT = 11;</code>
     */
    public static final int SHORT_VALUE = 11;
    /**
     * <code>INTEGER = 12;</code>
     */
    public static final int INTEGER_VALUE = 12;
    /**
     * <code>LONG = 13;</code>
     */
    public static final int LONG_VALUE = 13;
    /**
     * <code>FLOAT = 14;</code>
     */
    public static final int FLOAT_VALUE = 14;
    /**
     * <code>DOUBLE = 15;</code>
     */
    public static final int DOUBLE_VALUE = 15;
    /**
     * <code>BIG_INTEGER = 25;</code>
     */
    public static final int BIG_INTEGER_VALUE = 25;
    /**
     * <code>BIG_DECIMAL = 26;</code>
     */
    public static final int BIG_DECIMAL_VALUE = 26;
    /**
     * <code>JAVA_SQL_TIME = 16;</code>
     */
    public static final int JAVA_SQL_TIME_VALUE = 16;
    /**
     * <code>JAVA_SQL_TIMESTAMP = 17;</code>
     */
    public static final int JAVA_SQL_TIMESTAMP_VALUE = 17;
    /**
     * <code>JAVA_SQL_DATE = 18;</code>
     */
    public static final int JAVA_SQL_DATE_VALUE = 18;
    /**
     * <code>JAVA_UTIL_DATE = 19;</code>
     */
    public static final int JAVA_UTIL_DATE_VALUE = 19;
    /**
     * <code>BYTE_STRING = 20;</code>
     */
    public static final int BYTE_STRING_VALUE = 20;
    /**
     * <code>STRING = 21;</code>
     */
    public static final int STRING_VALUE = 21;
    /**
     * <code>NUMBER = 22;</code>
     */
    public static final int NUMBER_VALUE = 22;
    /**
     * <code>OBJECT = 23;</code>
     */
    public static final int OBJECT_VALUE = 23;
    /**
     * <code>NULL = 24;</code>
     */
    public static final int NULL_VALUE = 24;
    /**
     * <code>ARRAY = 27;</code>
     */
    public static final int ARRAY_VALUE = 27;
    /**
     * <code>STRUCT = 28;</code>
     */
    public static final int STRUCT_VALUE = 28;
    /**
     * <code>MULTISET = 29;</code>
     */
    public static final int MULTISET_VALUE = 29;


    public final int getNumber() {
      if (this == UNRECOGNIZED) {
        throw new java.lang.IllegalArgumentException(
            "Can't get the number of an unknown enum value.");
      }
      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 Rep 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 Rep forNumber(int value) {
      switch (value) {
        case 0: return PRIMITIVE_BOOLEAN;
        case 1: return PRIMITIVE_BYTE;
        case 2: return PRIMITIVE_CHAR;
        case 3: return PRIMITIVE_SHORT;
        case 4: return PRIMITIVE_INT;
        case 5: return PRIMITIVE_LONG;
        case 6: return PRIMITIVE_FLOAT;
        case 7: return PRIMITIVE_DOUBLE;
        case 8: return BOOLEAN;
        case 9: return BYTE;
        case 10: return CHARACTER;
        case 11: return SHORT;
        case 12: return INTEGER;
        case 13: return LONG;
        case 14: return FLOAT;
        case 15: return DOUBLE;
        case 25: return BIG_INTEGER;
        case 26: return BIG_DECIMAL;
        case 16: return JAVA_SQL_TIME;
        case 17: return JAVA_SQL_TIMESTAMP;
        case 18: return JAVA_SQL_DATE;
        case 19: return JAVA_UTIL_DATE;
        case 20: return BYTE_STRING;
        case 21: return STRING;
        case 22: return NUMBER;
        case 23: return OBJECT;
        case 24: return NULL;
        case 27: return ARRAY;
        case 28: return STRUCT;
        case 29: return MULTISET;
        default: return null;
      }
    }

    public static com.google.protobuf.Internal.EnumLiteMap<Rep>
        internalGetValueMap() {
      return internalValueMap;
    }
    private static final com.google.protobuf.Internal.EnumLiteMap<
        Rep> internalValueMap =
          new com.google.protobuf.Internal.EnumLiteMap<Rep>() {
            public Rep findValueByNumber(int number) {
              return Rep.forNumber(number);
            }
          };

    public final com.google.protobuf.Descriptors.EnumValueDescriptor
        getValueDescriptor() {
      if (this == UNRECOGNIZED) {
        throw new java.lang.IllegalStateException(
            "Can't get the descriptor of an unrecognized enum value.");
      }
      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 org.apache.calcite.avatica.proto.Common.getDescriptor().getEnumTypes().get(1);
    }

    private static final Rep[] VALUES = values();

    public static Rep valueOf(
        com.google.protobuf.Descriptors.EnumValueDescriptor desc) {
      if (desc.getType() != getDescriptor()) {
        throw new java.lang.IllegalArgumentException(
          "EnumValueDescriptor is not for this type.");
      }
      if (desc.getIndex() == -1) {
        return UNRECOGNIZED;
      }
      return VALUES[desc.getIndex()];
    }

    private final int value;

    private Rep(int value) {
      this.value = value;
    }

    // @@protoc_insertion_point(enum_scope:Rep)
  }

  /**
   * <pre>
   * The severity of some unexpected outcome to an operation.
   * Protobuf enum values must be unique across all other enums
   * </pre>
   *
   * Protobuf enum {@code Severity}
   */
  public enum Severity
      implements com.google.protobuf.ProtocolMessageEnum {
    /**
     * <code>UNKNOWN_SEVERITY = 0;</code>
     */
    UNKNOWN_SEVERITY(0),
    /**
     * <code>FATAL_SEVERITY = 1;</code>
     */
    FATAL_SEVERITY(1),
    /**
     * <code>ERROR_SEVERITY = 2;</code>
     */
    ERROR_SEVERITY(2),
    /**
     * <code>WARNING_SEVERITY = 3;</code>
     */
    WARNING_SEVERITY(3),
    UNRECOGNIZED(-1),
    ;

    /**
     * <code>UNKNOWN_SEVERITY = 0;</code>
     */
    public static final int UNKNOWN_SEVERITY_VALUE = 0;
    /**
     * <code>FATAL_SEVERITY = 1;</code>
     */
    public static final int FATAL_SEVERITY_VALUE = 1;
    /**
     * <code>ERROR_SEVERITY = 2;</code>
     */
    public static final int ERROR_SEVERITY_VALUE = 2;
    /**
     * <code>WARNING_SEVERITY = 3;</code>
     */
    public static final int WARNING_SEVERITY_VALUE = 3;


    public final int getNumber() {
      if (this == UNRECOGNIZED) {
        throw new java.lang.IllegalArgumentException(
            "Can't get the number of an unknown enum value.");
      }
      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 Severity 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 Severity forNumber(int value) {
      switch (value) {
        case 0: return UNKNOWN_SEVERITY;
        case 1: return FATAL_SEVERITY;
        case 2: return ERROR_SEVERITY;
        case 3: return WARNING_SEVERITY;
        default: return null;
      }
    }

    public static com.google.protobuf.Internal.EnumLiteMap<Severity>
        internalGetValueMap() {
      return internalValueMap;
    }
    private static final com.google.protobuf.Internal.EnumLiteMap<
        Severity> internalValueMap =
          new com.google.protobuf.Internal.EnumLiteMap<Severity>() {
            public Severity findValueByNumber(int number) {
              return Severity.forNumber(number);
            }
          };

    public final com.google.protobuf.Descriptors.EnumValueDescriptor
        getValueDescriptor() {
      if (this == UNRECOGNIZED) {
        throw new java.lang.IllegalStateException(
            "Can't get the descriptor of an unrecognized enum value.");
      }
      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 org.apache.calcite.avatica.proto.Common.getDescriptor().getEnumTypes().get(2);
    }

    private static final Severity[] VALUES = values();

    public static Severity valueOf(
        com.google.protobuf.Descriptors.EnumValueDescriptor desc) {
      if (desc.getType() != getDescriptor()) {
        throw new java.lang.IllegalArgumentException(
          "EnumValueDescriptor is not for this type.");
      }
      if (desc.getIndex() == -1) {
        return UNRECOGNIZED;
      }
      return VALUES[desc.getIndex()];
    }

    private final int value;

    private Severity(int value) {
      this.value = value;
    }

    // @@protoc_insertion_point(enum_scope:Severity)
  }

  /**
   * <pre>
   * Enumeration corresponding to DatabaseMetaData operations
   * </pre>
   *
   * Protobuf enum {@code MetaDataOperation}
   */
  public enum MetaDataOperation
      implements com.google.protobuf.ProtocolMessageEnum {
    /**
     * <code>GET_ATTRIBUTES = 0;</code>
     */
    GET_ATTRIBUTES(0),
    /**
     * <code>GET_BEST_ROW_IDENTIFIER = 1;</code>
     */
    GET_BEST_ROW_IDENTIFIER(1),
    /**
     * <code>GET_CATALOGS = 2;</code>
     */
    GET_CATALOGS(2),
    /**
     * <code>GET_CLIENT_INFO_PROPERTIES = 3;</code>
     */
    GET_CLIENT_INFO_PROPERTIES(3),
    /**
     * <code>GET_COLUMN_PRIVILEGES = 4;</code>
     */
    GET_COLUMN_PRIVILEGES(4),
    /**
     * <code>GET_COLUMNS = 5;</code>
     */
    GET_COLUMNS(5),
    /**
     * <code>GET_CROSS_REFERENCE = 6;</code>
     */
    GET_CROSS_REFERENCE(6),
    /**
     * <code>GET_EXPORTED_KEYS = 7;</code>
     */
    GET_EXPORTED_KEYS(7),
    /**
     * <code>GET_FUNCTION_COLUMNS = 8;</code>
     */
    GET_FUNCTION_COLUMNS(8),
    /**
     * <code>GET_FUNCTIONS = 9;</code>
     */
    GET_FUNCTIONS(9),
    /**
     * <code>GET_IMPORTED_KEYS = 10;</code>
     */
    GET_IMPORTED_KEYS(10),
    /**
     * <code>GET_INDEX_INFO = 11;</code>
     */
    GET_INDEX_INFO(11),
    /**
     * <code>GET_PRIMARY_KEYS = 12;</code>
     */
    GET_PRIMARY_KEYS(12),
    /**
     * <code>GET_PROCEDURE_COLUMNS = 13;</code>
     */
    GET_PROCEDURE_COLUMNS(13),
    /**
     * <code>GET_PROCEDURES = 14;</code>
     */
    GET_PROCEDURES(14),
    /**
     * <code>GET_PSEUDO_COLUMNS = 15;</code>
     */
    GET_PSEUDO_COLUMNS(15),
    /**
     * <code>GET_SCHEMAS = 16;</code>
     */
    GET_SCHEMAS(16),
    /**
     * <code>GET_SCHEMAS_WITH_ARGS = 17;</code>
     */
    GET_SCHEMAS_WITH_ARGS(17),
    /**
     * <code>GET_SUPER_TABLES = 18;</code>
     */
    GET_SUPER_TABLES(18),
    /**
     * <code>GET_SUPER_TYPES = 19;</code>
     */
    GET_SUPER_TYPES(19),
    /**
     * <code>GET_TABLE_PRIVILEGES = 20;</code>
     */
    GET_TABLE_PRIVILEGES(20),
    /**
     * <code>GET_TABLES = 21;</code>
     */
    GET_TABLES(21),
    /**
     * <code>GET_TABLE_TYPES = 22;</code>
     */
    GET_TABLE_TYPES(22),
    /**
     * <code>GET_TYPE_INFO = 23;</code>
     */
    GET_TYPE_INFO(23),
    /**
     * <code>GET_UDTS = 24;</code>
     */
    GET_UDTS(24),
    /**
     * <code>GET_VERSION_COLUMNS = 25;</code>
     */
    GET_VERSION_COLUMNS(25),
    UNRECOGNIZED(-1),
    ;

    /**
     * <code>GET_ATTRIBUTES = 0;</code>
     */
    public static final int GET_ATTRIBUTES_VALUE = 0;
    /**
     * <code>GET_BEST_ROW_IDENTIFIER = 1;</code>
     */
    public static final int GET_BEST_ROW_IDENTIFIER_VALUE = 1;
    /**
     * <code>GET_CATALOGS = 2;</code>
     */
    public static final int GET_CATALOGS_VALUE = 2;
    /**
     * <code>GET_CLIENT_INFO_PROPERTIES = 3;</code>
     */
    public static final int GET_CLIENT_INFO_PROPERTIES_VALUE = 3;
    /**
     * <code>GET_COLUMN_PRIVILEGES = 4;</code>
     */
    public static final int GET_COLUMN_PRIVILEGES_VALUE = 4;
    /**
     * <code>GET_COLUMNS = 5;</code>
     */
    public static final int GET_COLUMNS_VALUE = 5;
    /**
     * <code>GET_CROSS_REFERENCE = 6;</code>
     */
    public static final int GET_CROSS_REFERENCE_VALUE = 6;
    /**
     * <code>GET_EXPORTED_KEYS = 7;</code>
     */
    public static final int GET_EXPORTED_KEYS_VALUE = 7;
    /**
     * <code>GET_FUNCTION_COLUMNS = 8;</code>
     */
    public static final int GET_FUNCTION_COLUMNS_VALUE = 8;
    /**
     * <code>GET_FUNCTIONS = 9;</code>
     */
    public static final int GET_FUNCTIONS_VALUE = 9;
    /**
     * <code>GET_IMPORTED_KEYS = 10;</code>
     */
    public static final int GET_IMPORTED_KEYS_VALUE = 10;
    /**
     * <code>GET_INDEX_INFO = 11;</code>
     */
    public static final int GET_INDEX_INFO_VALUE = 11;
    /**
     * <code>GET_PRIMARY_KEYS = 12;</code>
     */
    public static final int GET_PRIMARY_KEYS_VALUE = 12;
    /**
     * <code>GET_PROCEDURE_COLUMNS = 13;</code>
     */
    public static final int GET_PROCEDURE_COLUMNS_VALUE = 13;
    /**
     * <code>GET_PROCEDURES = 14;</code>
     */
    public static final int GET_PROCEDURES_VALUE = 14;
    /**
     * <code>GET_PSEUDO_COLUMNS = 15;</code>
     */
    public static final int GET_PSEUDO_COLUMNS_VALUE = 15;
    /**
     * <code>GET_SCHEMAS = 16;</code>
     */
    public static final int GET_SCHEMAS_VALUE = 16;
    /**
     * <code>GET_SCHEMAS_WITH_ARGS = 17;</code>
     */
    public static final int GET_SCHEMAS_WITH_ARGS_VALUE = 17;
    /**
     * <code>GET_SUPER_TABLES = 18;</code>
     */
    public static final int GET_SUPER_TABLES_VALUE = 18;
    /**
     * <code>GET_SUPER_TYPES = 19;</code>
     */
    public static final int GET_SUPER_TYPES_VALUE = 19;
    /**
     * <code>GET_TABLE_PRIVILEGES = 20;</code>
     */
    public static final int GET_TABLE_PRIVILEGES_VALUE = 20;
    /**
     * <code>GET_TABLES = 21;</code>
     */
    public static final int GET_TABLES_VALUE = 21;
    /**
     * <code>GET_TABLE_TYPES = 22;</code>
     */
    public static final int GET_TABLE_TYPES_VALUE = 22;
    /**
     * <code>GET_TYPE_INFO = 23;</code>
     */
    public static final int GET_TYPE_INFO_VALUE = 23;
    /**
     * <code>GET_UDTS = 24;</code>
     */
    public static final int GET_UDTS_VALUE = 24;
    /**
     * <code>GET_VERSION_COLUMNS = 25;</code>
     */
    public static final int GET_VERSION_COLUMNS_VALUE = 25;


    public final int getNumber() {
      if (this == UNRECOGNIZED) {
        throw new java.lang.IllegalArgumentException(
            "Can't get the number of an unknown enum value.");
      }
      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 MetaDataOperation 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 MetaDataOperation forNumber(int value) {
      switch (value) {
        case 0: return GET_ATTRIBUTES;
        case 1: return GET_BEST_ROW_IDENTIFIER;
        case 2: return GET_CATALOGS;
        case 3: return GET_CLIENT_INFO_PROPERTIES;
        case 4: return GET_COLUMN_PRIVILEGES;
        case 5: return GET_COLUMNS;
        case 6: return GET_CROSS_REFERENCE;
        case 7: return GET_EXPORTED_KEYS;
        case 8: return GET_FUNCTION_COLUMNS;
        case 9: return GET_FUNCTIONS;
        case 10: return GET_IMPORTED_KEYS;
        case 11: return GET_INDEX_INFO;
        case 12: return GET_PRIMARY_KEYS;
        case 13: return GET_PROCEDURE_COLUMNS;
        case 14: return GET_PROCEDURES;
        case 15: return GET_PSEUDO_COLUMNS;
        case 16: return GET_SCHEMAS;
        case 17: return GET_SCHEMAS_WITH_ARGS;
        case 18: return GET_SUPER_TABLES;
        case 19: return GET_SUPER_TYPES;
        case 20: return GET_TABLE_PRIVILEGES;
        case 21: return GET_TABLES;
        case 22: return GET_TABLE_TYPES;
        case 23: return GET_TYPE_INFO;
        case 24: return GET_UDTS;
        case 25: return GET_VERSION_COLUMNS;
        default: return null;
      }
    }

    public static com.google.protobuf.Internal.EnumLiteMap<MetaDataOperation>
        internalGetValueMap() {
      return internalValueMap;
    }
    private static final com.google.protobuf.Internal.EnumLiteMap<
        MetaDataOperation> internalValueMap =
          new com.google.protobuf.Internal.EnumLiteMap<MetaDataOperation>() {
            public MetaDataOperation findValueByNumber(int number) {
              return MetaDataOperation.forNumber(number);
            }
          };

    public final com.google.protobuf.Descriptors.EnumValueDescriptor
        getValueDescriptor() {
      if (this == UNRECOGNIZED) {
        throw new java.lang.IllegalStateException(
            "Can't get the descriptor of an unrecognized enum value.");
      }
      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 org.apache.calcite.avatica.proto.Common.getDescriptor().getEnumTypes().get(3);
    }

    private static final MetaDataOperation[] VALUES = values();

    public static MetaDataOperation valueOf(
        com.google.protobuf.Descriptors.EnumValueDescriptor desc) {
      if (desc.getType() != getDescriptor()) {
        throw new java.lang.IllegalArgumentException(
          "EnumValueDescriptor is not for this type.");
      }
      if (desc.getIndex() == -1) {
        return UNRECOGNIZED;
      }
      return VALUES[desc.getIndex()];
    }

    private final int value;

    private MetaDataOperation(int value) {
      this.value = value;
    }

    // @@protoc_insertion_point(enum_scope:MetaDataOperation)
  }

  /**
   * Protobuf enum {@code StateType}
   */
  public enum StateType
      implements com.google.protobuf.ProtocolMessageEnum {
    /**
     * <code>SQL = 0;</code>
     */
    SQL(0),
    /**
     * <code>METADATA = 1;</code>
     */
    METADATA(1),
    UNRECOGNIZED(-1),
    ;

    /**
     * <code>SQL = 0;</code>
     */
    public static final int SQL_VALUE = 0;
    /**
     * <code>METADATA = 1;</code>
     */
    public static final int METADATA_VALUE = 1;


    public final int getNumber() {
      if (this == UNRECOGNIZED) {
        throw new java.lang.IllegalArgumentException(
            "Can't get the number of an unknown enum value.");
      }
      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 StateType 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 StateType forNumber(int value) {
      switch (value) {
        case 0: return SQL;
        case 1: return METADATA;
        default: return null;
      }
    }

    public static com.google.protobuf.Internal.EnumLiteMap<StateType>
        internalGetValueMap() {
      return internalValueMap;
    }
    private static final com.google.protobuf.Internal.EnumLiteMap<
        StateType> internalValueMap =
          new com.google.protobuf.Internal.EnumLiteMap<StateType>() {
            public StateType findValueByNumber(int number) {
              return StateType.forNumber(number);
            }
          };

    public final com.google.protobuf.Descriptors.EnumValueDescriptor
        getValueDescriptor() {
      if (this == UNRECOGNIZED) {
        throw new java.lang.IllegalStateException(
            "Can't get the descriptor of an unrecognized enum value.");
      }
      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 org.apache.calcite.avatica.proto.Common.getDescriptor().getEnumTypes().get(4);
    }

    private static final StateType[] VALUES = values();

    public static StateType valueOf(
        com.google.protobuf.Descriptors.EnumValueDescriptor desc) {
      if (desc.getType() != getDescriptor()) {
        throw new java.lang.IllegalArgumentException(
          "EnumValueDescriptor is not for this type.");
      }
      if (desc.getIndex() == -1) {
        return UNRECOGNIZED;
      }
      return VALUES[desc.getIndex()];
    }

    private final int value;

    private StateType(int value) {
      this.value = value;
    }

    // @@protoc_insertion_point(enum_scope:StateType)
  }

  public interface ConnectionPropertiesOrBuilder extends
      // @@protoc_insertion_point(interface_extends:ConnectionProperties)
      com.google.protobuf.MessageOrBuilder {

    /**
     * <code>bool is_dirty = 1;</code>
     * @return The isDirty.
     */
    boolean getIsDirty();

    /**
     * <code>bool auto_commit = 2;</code>
     * @return The autoCommit.
     */
    boolean getAutoCommit();

    /**
     * <pre>
     * field is a Boolean, need to discern null and default value
     * </pre>
     *
     * <code>bool has_auto_commit = 7;</code>
     * @return The hasAutoCommit.
     */
    boolean getHasAutoCommit();

    /**
     * <code>bool read_only = 3;</code>
     * @return The readOnly.
     */
    boolean getReadOnly();

    /**
     * <pre>
     * field is a Boolean, need to discern null and default value
     * </pre>
     *
     * <code>bool has_read_only = 8;</code>
     * @return The hasReadOnly.
     */
    boolean getHasReadOnly();

    /**
     * <code>uint32 transaction_isolation = 4;</code>
     * @return The transactionIsolation.
     */
    int getTransactionIsolation();

    /**
     * <code>string catalog = 5;</code>
     * @return The catalog.
     */
    java.lang.String getCatalog();
    /**
     * <code>string catalog = 5;</code>
     * @return The bytes for catalog.
     */
    com.google.protobuf.ByteString
        getCatalogBytes();

    /**
     * <code>string schema = 6;</code>
     * @return The schema.
     */
    java.lang.String getSchema();
    /**
     * <code>string schema = 6;</code>
     * @return The bytes for schema.
     */
    com.google.protobuf.ByteString
        getSchemaBytes();
  }
  /**
   * <pre>
   * Details about a connection
   * </pre>
   *
   * Protobuf type {@code ConnectionProperties}
   */
  public static final class ConnectionProperties extends
      com.google.protobuf.GeneratedMessageV3 implements
      // @@protoc_insertion_point(message_implements:ConnectionProperties)
      ConnectionPropertiesOrBuilder {
  private static final long serialVersionUID = 0L;
    // Use ConnectionProperties.newBuilder() to construct.
    private ConnectionProperties(com.google.protobuf.GeneratedMessageV3.Builder<?> builder) {
      super(builder);
    }
    private ConnectionProperties() {
      catalog_ = "";
      schema_ = "";
    }

    @java.lang.Override
    @SuppressWarnings({"unused"})
    protected java.lang.Object newInstance(
        UnusedPrivateParameter unused) {
      return new ConnectionProperties();
    }

    @java.lang.Override
    public final com.google.protobuf.UnknownFieldSet
    getUnknownFields() {
      return this.unknownFields;
    }
    public static final com.google.protobuf.Descriptors.Descriptor
        getDescriptor() {
      return org.apache.calcite.avatica.proto.Common.internal_static_ConnectionProperties_descriptor;
    }

    @java.lang.Override
    protected com.google.protobuf.GeneratedMessageV3.FieldAccessorTable
        internalGetFieldAccessorTable() {
      return org.apache.calcite.avatica.proto.Common.internal_static_ConnectionProperties_fieldAccessorTable
          .ensureFieldAccessorsInitialized(
              org.apache.calcite.avatica.proto.Common.ConnectionProperties.class, org.apache.calcite.avatica.proto.Common.ConnectionProperties.Builder.class);
    }

    public static final int IS_DIRTY_FIELD_NUMBER = 1;
    private boolean isDirty_;
    /**
     * <code>bool is_dirty = 1;</code>
     * @return The isDirty.
     */
    @java.lang.Override
    public boolean getIsDirty() {
      return isDirty_;
    }

    public static final int AUTO_COMMIT_FIELD_NUMBER = 2;
    private boolean autoCommit_;
    /**
     * <code>bool auto_commit = 2;</code>
     * @return The autoCommit.
     */
    @java.lang.Override
    public boolean getAutoCommit() {
      return autoCommit_;
    }

    public static final int HAS_AUTO_COMMIT_FIELD_NUMBER = 7;
    private boolean hasAutoCommit_;
    /**
     * <pre>
     * field is a Boolean, need to discern null and default value
     * </pre>
     *
     * <code>bool has_auto_commit = 7;</code>
     * @return The hasAutoCommit.
     */
    @java.lang.Override
    public boolean getHasAutoCommit() {
      return hasAutoCommit_;
    }

    public static final int READ_ONLY_FIELD_NUMBER = 3;
    private boolean readOnly_;
    /**
     * <code>bool read_only = 3;</code>
     * @return The readOnly.
     */
    @java.lang.Override
    public boolean getReadOnly() {
      return readOnly_;
    }

    public static final int HAS_READ_ONLY_FIELD_NUMBER = 8;
    private boolean hasReadOnly_;
    /**
     * <pre>
     * field is a Boolean, need to discern null and default value
     * </pre>
     *
     * <code>bool has_read_only = 8;</code>
     * @return The hasReadOnly.
     */
    @java.lang.Override
    public boolean getHasReadOnly() {
      return hasReadOnly_;
    }

    public static final int TRANSACTION_ISOLATION_FIELD_NUMBER = 4;
    private int transactionIsolation_;
    /**
     * <code>uint32 transaction_isolation = 4;</code>
     * @return The transactionIsolation.
     */
    @java.lang.Override
    public int getTransactionIsolation() {
      return transactionIsolation_;
    }

    public static final int CATALOG_FIELD_NUMBER = 5;
    private volatile java.lang.Object catalog_;
    /**
     * <code>string catalog = 5;</code>
     * @return The catalog.
     */
    @java.lang.Override
    public java.lang.String getCatalog() {
      java.lang.Object ref = catalog_;
      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();
        catalog_ = s;
        return s;
      }
    }
    /**
     * <code>string catalog = 5;</code>
     * @return The bytes for catalog.
     */
    @java.lang.Override
    public com.google.protobuf.ByteString
        getCatalogBytes() {
      java.lang.Object ref = catalog_;
      if (ref instanceof java.lang.String) {
        com.google.protobuf.ByteString b = 
            com.google.protobuf.ByteString.copyFromUtf8(
                (java.lang.String) ref);
        catalog_ = b;
        return b;
      } else {
        return (com.google.protobuf.ByteString) ref;
      }
    }

    public static final int SCHEMA_FIELD_NUMBER = 6;
    private volatile java.lang.Object schema_;
    /**
     * <code>string schema = 6;</code>
     * @return The schema.
     */
    @java.lang.Override
    public java.lang.String getSchema() {
      java.lang.Object ref = schema_;
      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();
        schema_ = s;
        return s;
      }
    }
    /**
     * <code>string schema = 6;</code>
     * @return The bytes for schema.
     */
    @java.lang.Override
    public com.google.protobuf.ByteString
        getSchemaBytes() {
      java.lang.Object ref = schema_;
      if (ref instanceof java.lang.String) {
        com.google.protobuf.ByteString b = 
            com.google.protobuf.ByteString.copyFromUtf8(
                (java.lang.String) ref);
        schema_ = 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 (isDirty_ != false) {
        output.writeBool(1, isDirty_);
      }
      if (autoCommit_ != false) {
        output.writeBool(2, autoCommit_);
      }
      if (readOnly_ != false) {
        output.writeBool(3, readOnly_);
      }
      if (transactionIsolation_ != 0) {
        output.writeUInt32(4, transactionIsolation_);
      }
      if (!com.google.protobuf.GeneratedMessageV3.isStringEmpty(catalog_)) {
        com.google.protobuf.GeneratedMessageV3.writeString(output, 5, catalog_);
      }
      if (!com.google.protobuf.GeneratedMessageV3.isStringEmpty(schema_)) {
        com.google.protobuf.GeneratedMessageV3.writeString(output, 6, schema_);
      }
      if (hasAutoCommit_ != false) {
        output.writeBool(7, hasAutoCommit_);
      }
      if (hasReadOnly_ != false) {
        output.writeBool(8, hasReadOnly_);
      }
      getUnknownFields().writeTo(output);
    }

    @java.lang.Override
    public int getSerializedSize() {
      int size = memoizedSize;
      if (size != -1) return size;

      size = 0;
      if (isDirty_ != false) {
        size += com.google.protobuf.CodedOutputStream
          .computeBoolSize(1, isDirty_);
      }
      if (autoCommit_ != false) {
        size += com.google.protobuf.CodedOutputStream
          .computeBoolSize(2, autoCommit_);
      }
      if (readOnly_ != false) {
        size += com.google.protobuf.CodedOutputStream
          .computeBoolSize(3, readOnly_);
      }
      if (transactionIsolation_ != 0) {
        size += com.google.protobuf.CodedOutputStream
          .computeUInt32Size(4, transactionIsolation_);
      }
      if (!com.google.protobuf.GeneratedMessageV3.isStringEmpty(catalog_)) {
        size += com.google.protobuf.GeneratedMessageV3.computeStringSize(5, catalog_);
      }
      if (!com.google.protobuf.GeneratedMessageV3.isStringEmpty(schema_)) {
        size += com.google.protobuf.GeneratedMessageV3.computeStringSize(6, schema_);
      }
      if (hasAutoCommit_ != false) {
        size += com.google.protobuf.CodedOutputStream
          .computeBoolSize(7, hasAutoCommit_);
      }
      if (hasReadOnly_ != false) {
        size += com.google.protobuf.CodedOutputStream
          .computeBoolSize(8, hasReadOnly_);
      }
      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 org.apache.calcite.avatica.proto.Common.ConnectionProperties)) {
        return super.equals(obj);
      }
      org.apache.calcite.avatica.proto.Common.ConnectionProperties other = (org.apache.calcite.avatica.proto.Common.ConnectionProperties) obj;

      if (getIsDirty()
          != other.getIsDirty()) return false;
      if (getAutoCommit()
          != other.getAutoCommit()) return false;
      if (getHasAutoCommit()
          != other.getHasAutoCommit()) return false;
      if (getReadOnly()
          != other.getReadOnly()) return false;
      if (getHasReadOnly()
          != other.getHasReadOnly()) return false;
      if (getTransactionIsolation()
          != other.getTransactionIsolation()) return false;
      if (!getCatalog()
          .equals(other.getCatalog())) return false;
      if (!getSchema()
          .equals(other.getSchema())) 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();
      hash = (37 * hash) + IS_DIRTY_FIELD_NUMBER;
      hash = (53 * hash) + com.google.protobuf.Internal.hashBoolean(
          getIsDirty());
      hash = (37 * hash) + AUTO_COMMIT_FIELD_NUMBER;
      hash = (53 * hash) + com.google.protobuf.Internal.hashBoolean(
          getAutoCommit());
      hash = (37 * hash) + HAS_AUTO_COMMIT_FIELD_NUMBER;
      hash = (53 * hash) + com.google.protobuf.Internal.hashBoolean(
          getHasAutoCommit());
      hash = (37 * hash) + READ_ONLY_FIELD_NUMBER;
      hash = (53 * hash) + com.google.protobuf.Internal.hashBoolean(
          getReadOnly());
      hash = (37 * hash) + HAS_READ_ONLY_FIELD_NUMBER;
      hash = (53 * hash) + com.google.protobuf.Internal.hashBoolean(
          getHasReadOnly());
      hash = (37 * hash) + TRANSACTION_ISOLATION_FIELD_NUMBER;
      hash = (53 * hash) + getTransactionIsolation();
      hash = (37 * hash) + CATALOG_FIELD_NUMBER;
      hash = (53 * hash) + getCatalog().hashCode();
      hash = (37 * hash) + SCHEMA_FIELD_NUMBER;
      hash = (53 * hash) + getSchema().hashCode();
      hash = (29 * hash) + getUnknownFields().hashCode();
      memoizedHashCode = hash;
      return hash;
    }

    public static org.apache.calcite.avatica.proto.Common.ConnectionProperties parseFrom(
        java.nio.ByteBuffer data)
        throws com.google.protobuf.InvalidProtocolBufferException {
      return PARSER.parseFrom(data);
    }
    public static org.apache.calcite.avatica.proto.Common.ConnectionProperties parseFrom(
        java.nio.ByteBuffer data,
        com.google.protobuf.ExtensionRegistryLite extensionRegistry)
        throws com.google.protobuf.InvalidProtocolBufferException {
      return PARSER.parseFrom(data, extensionRegistry);
    }
    public static org.apache.calcite.avatica.proto.Common.ConnectionProperties parseFrom(
        com.google.protobuf.ByteString data)
        throws com.google.protobuf.InvalidProtocolBufferException {
      return PARSER.parseFrom(data);
    }
    public static org.apache.calcite.avatica.proto.Common.ConnectionProperties parseFrom(
        com.google.protobuf.ByteString data,
        com.google.protobuf.ExtensionRegistryLite extensionRegistry)
        throws com.google.protobuf.InvalidProtocolBufferException {
      return PARSER.parseFrom(data, extensionRegistry);
    }
    public static org.apache.calcite.avatica.proto.Common.ConnectionProperties parseFrom(byte[] data)
        throws com.google.protobuf.InvalidProtocolBufferException {
      return PARSER.parseFrom(data);
    }
    public static org.apache.calcite.avatica.proto.Common.ConnectionProperties parseFrom(
        byte[] data,
        com.google.protobuf.ExtensionRegistryLite extensionRegistry)
        throws com.google.protobuf.InvalidProtocolBufferException {
      return PARSER.parseFrom(data, extensionRegistry);
    }
    public static org.apache.calcite.avatica.proto.Common.ConnectionProperties parseFrom(java.io.InputStream input)
        throws java.io.IOException {
      return com.google.protobuf.GeneratedMessageV3
          .parseWithIOException(PARSER, input);
    }
    public static org.apache.calcite.avatica.proto.Common.ConnectionProperties 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 org.apache.calcite.avatica.proto.Common.ConnectionProperties parseDelimitedFrom(java.io.InputStream input)
        throws java.io.IOException {
      return com.google.protobuf.GeneratedMessageV3
          .parseDelimitedWithIOException(PARSER, input);
    }
    public static org.apache.calcite.avatica.proto.Common.ConnectionProperties 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 org.apache.calcite.avatica.proto.Common.ConnectionProperties parseFrom(
        com.google.protobuf.CodedInputStream input)
        throws java.io.IOException {
      return com.google.protobuf.GeneratedMessageV3
          .parseWithIOException(PARSER, input);
    }
    public static org.apache.calcite.avatica.proto.Common.ConnectionProperties 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(org.apache.calcite.avatica.proto.Common.ConnectionProperties 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;
    }
    /**
     * <pre>
     * Details about a connection
     * </pre>
     *
     * Protobuf type {@code ConnectionProperties}
     */
    public static final class Builder extends
        com.google.protobuf.GeneratedMessageV3.Builder<Builder> implements
        // @@protoc_insertion_point(builder_implements:ConnectionProperties)
        org.apache.calcite.avatica.proto.Common.ConnectionPropertiesOrBuilder {
      public static final com.google.protobuf.Descriptors.Descriptor
          getDescriptor() {
        return org.apache.calcite.avatica.proto.Common.internal_static_ConnectionProperties_descriptor;
      }

      @java.lang.Override
      protected com.google.protobuf.GeneratedMessageV3.FieldAccessorTable
          internalGetFieldAccessorTable() {
        return org.apache.calcite.avatica.proto.Common.internal_static_ConnectionProperties_fieldAccessorTable
            .ensureFieldAccessorsInitialized(
                org.apache.calcite.avatica.proto.Common.ConnectionProperties.class, org.apache.calcite.avatica.proto.Common.ConnectionProperties.Builder.class);
      }

      // Construct using org.apache.calcite.avatica.proto.Common.ConnectionProperties.newBuilder()
      private Builder() {

      }

      private Builder(
          com.google.protobuf.GeneratedMessageV3.BuilderParent parent) {
        super(parent);

      }
      @java.lang.Override
      public Builder clear() {
        super.clear();
        isDirty_ = false;

        autoCommit_ = false;

        hasAutoCommit_ = false;

        readOnly_ = false;

        hasReadOnly_ = false;

        transactionIsolation_ = 0;

        catalog_ = "";

        schema_ = "";

        return this;
      }

      @java.lang.Override
      public com.google.protobuf.Descriptors.Descriptor
          getDescriptorForType() {
        return org.apache.calcite.avatica.proto.Common.internal_static_ConnectionProperties_descriptor;
      }

      @java.lang.Override
      public org.apache.calcite.avatica.proto.Common.ConnectionProperties getDefaultInstanceForType() {
        return org.apache.calcite.avatica.proto.Common.ConnectionProperties.getDefaultInstance();
      }

      @java.lang.Override
      public org.apache.calcite.avatica.proto.Common.ConnectionProperties build() {
        org.apache.calcite.avatica.proto.Common.ConnectionProperties result = buildPartial();
        if (!result.isInitialized()) {
          throw newUninitializedMessageException(result);
        }
        return result;
      }

      @java.lang.Override
      public org.apache.calcite.avatica.proto.Common.ConnectionProperties buildPartial() {
        org.apache.calcite.avatica.proto.Common.ConnectionProperties result = new org.apache.calcite.avatica.proto.Common.ConnectionProperties(this);
        result.isDirty_ = isDirty_;
        result.autoCommit_ = autoCommit_;
        result.hasAutoCommit_ = hasAutoCommit_;
        result.readOnly_ = readOnly_;
        result.hasReadOnly_ = hasReadOnly_;
        result.transactionIsolation_ = transactionIsolation_;
        result.catalog_ = catalog_;
        result.schema_ = schema_;
        onBuilt();
        return result;
      }

      @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 org.apache.calcite.avatica.proto.Common.ConnectionProperties) {
          return mergeFrom((org.apache.calcite.avatica.proto.Common.ConnectionProperties)other);
        } else {
          super.mergeFrom(other);
          return this;
        }
      }

      public Builder mergeFrom(org.apache.calcite.avatica.proto.Common.ConnectionProperties other) {
        if (other == org.apache.calcite.avatica.proto.Common.ConnectionProperties.getDefaultInstance()) return this;
        if (other.getIsDirty() != false) {
          setIsDirty(other.getIsDirty());
        }
        if (other.getAutoCommit() != false) {
          setAutoCommit(other.getAutoCommit());
        }
        if (other.getHasAutoCommit() != false) {
          setHasAutoCommit(other.getHasAutoCommit());
        }
        if (other.getReadOnly() != false) {
          setReadOnly(other.getReadOnly());
        }
        if (other.getHasReadOnly() != false) {
          setHasReadOnly(other.getHasReadOnly());
        }
        if (other.getTransactionIsolation() != 0) {
          setTransactionIsolation(other.getTransactionIsolation());
        }
        if (!other.getCatalog().isEmpty()) {
          catalog_ = other.catalog_;
          onChanged();
        }
        if (!other.getSchema().isEmpty()) {
          schema_ = other.schema_;
          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: {
                isDirty_ = input.readBool();

                break;
              } // case 8
              case 16: {
                autoCommit_ = input.readBool();

                break;
              } // case 16
              case 24: {
                readOnly_ = input.readBool();

                break;
              } // case 24
              case 32: {
                transactionIsolation_ = input.readUInt32();

                break;
              } // case 32
              case 42: {
                catalog_ = input.readStringRequireUtf8();

                break;
              } // case 42
              case 50: {
                schema_ = input.readStringRequireUtf8();

                break;
              } // case 50
              case 56: {
                hasAutoCommit_ = input.readBool();

                break;
              } // case 56
              case 64: {
                hasReadOnly_ = input.readBool();

                break;
              } // case 64
              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 boolean isDirty_ ;
      /**
       * <code>bool is_dirty = 1;</code>
       * @return The isDirty.
       */
      @java.lang.Override
      public boolean getIsDirty() {
        return isDirty_;
      }
      /**
       * <code>bool is_dirty = 1;</code>
       * @param value The isDirty to set.
       * @return This builder for chaining.
       */
      public Builder setIsDirty(boolean value) {
        
        isDirty_ = value;
        onChanged();
        return this;
      }
      /**
       * <code>bool is_dirty = 1;</code>
       * @return This builder for chaining.
       */
      public Builder clearIsDirty() {
        
        isDirty_ = false;
        onChanged();
        return this;
      }

      private boolean autoCommit_ ;
      /**
       * <code>bool auto_commit = 2;</code>
       * @return The autoCommit.
       */
      @java.lang.Override
      public boolean getAutoCommit() {
        return autoCommit_;
      }
      /**
       * <code>bool auto_commit = 2;</code>
       * @param value The autoCommit to set.
       * @return This builder for chaining.
       */
      public Builder setAutoCommit(boolean value) {
        
        autoCommit_ = value;
        onChanged();
        return this;
      }
      /**
       * <code>bool auto_commit = 2;</code>
       * @return This builder for chaining.
       */
      public Builder clearAutoCommit() {
        
        autoCommit_ = false;
        onChanged();
        return this;
      }

      private boolean hasAutoCommit_ ;
      /**
       * <pre>
       * field is a Boolean, need to discern null and default value
       * </pre>
       *
       * <code>bool has_auto_commit = 7;</code>
       * @return The hasAutoCommit.
       */
      @java.lang.Override
      public boolean getHasAutoCommit() {
        return hasAutoCommit_;
      }
      /**
       * <pre>
       * field is a Boolean, need to discern null and default value
       * </pre>
       *
       * <code>bool has_auto_commit = 7;</code>
       * @param value The hasAutoCommit to set.
       * @return This builder for chaining.
       */
      public Builder setHasAutoCommit(boolean value) {
        
        hasAutoCommit_ = value;
        onChanged();
        return this;
      }
      /**
       * <pre>
       * field is a Boolean, need to discern null and default value
       * </pre>
       *
       * <code>bool has_auto_commit = 7;</code>
       * @return This builder for chaining.
       */
      public Builder clearHasAutoCommit() {
        
        hasAutoCommit_ = false;
        onChanged();
        return this;
      }

      private boolean readOnly_ ;
      /**
       * <code>bool read_only = 3;</code>
       * @return The readOnly.
       */
      @java.lang.Override
      public boolean getReadOnly() {
        return readOnly_;
      }
      /**
       * <code>bool read_only = 3;</code>
       * @param value The readOnly to set.
       * @return This builder for chaining.
       */
      public Builder setReadOnly(boolean value) {
        
        readOnly_ = value;
        onChanged();
        return this;
      }
      /**
       * <code>bool read_only = 3;</code>
       * @return This builder for chaining.
       */
      public Builder clearReadOnly() {
        
        readOnly_ = false;
        onChanged();
        return this;
      }

      private boolean hasReadOnly_ ;
      /**
       * <pre>
       * field is a Boolean, need to discern null and default value
       * </pre>
       *
       * <code>bool has_read_only = 8;</code>
       * @return The hasReadOnly.
       */
      @java.lang.Override
      public boolean getHasReadOnly() {
        return hasReadOnly_;
      }
      /**
       * <pre>
       * field is a Boolean, need to discern null and default value
       * </pre>
       *
       * <code>bool has_read_only = 8;</code>
       * @param value The hasReadOnly to set.
       * @return This builder for chaining.
       */
      public Builder setHasReadOnly(boolean value) {
        
        hasReadOnly_ = value;
        onChanged();
        return this;
      }
      /**
       * <pre>
       * field is a Boolean, need to discern null and default value
       * </pre>
       *
       * <code>bool has_read_only = 8;</code>
       * @return This builder for chaining.
       */
      public Builder clearHasReadOnly() {
        
        hasReadOnly_ = false;
        onChanged();
        return this;
      }

      private int transactionIsolation_ ;
      /**
       * <code>uint32 transaction_isolation = 4;</code>
       * @return The transactionIsolation.
       */
      @java.lang.Override
      public int getTransactionIsolation() {
        return transactionIsolation_;
      }
      /**
       * <code>uint32 transaction_isolation = 4;</code>
       * @param value The transactionIsolation to set.
       * @return This builder for chaining.
       */
      public Builder setTransactionIsolation(int value) {
        
        transactionIsolation_ = value;
        onChanged();
        return this;
      }
      /**
       * <code>uint32 transaction_isolation = 4;</code>
       * @return This builder for chaining.
       */
      public Builder clearTransactionIsolation() {
        
        transactionIsolation_ = 0;
        onChanged();
        return this;
      }

      private java.lang.Object catalog_ = "";
      /**
       * <code>string catalog = 5;</code>
       * @return The catalog.
       */
      public java.lang.String getCatalog() {
        java.lang.Object ref = catalog_;
        if (!(ref instanceof java.lang.String)) {
          com.google.protobuf.ByteString bs =
              (com.google.protobuf.ByteString) ref;
          java.lang.String s = bs.toStringUtf8();
          catalog_ = s;
          return s;
        } else {
          return (java.lang.String) ref;
        }
      }
      /**
       * <code>string catalog = 5;</code>
       * @return The bytes for catalog.
       */
      public com.google.protobuf.ByteString
          getCatalogBytes() {
        java.lang.Object ref = catalog_;
        if (ref instanceof String) {
          com.google.protobuf.ByteString b = 
              com.google.protobuf.ByteString.copyFromUtf8(
                  (java.lang.String) ref);
          catalog_ = b;
          return b;
        } else {
          return (com.google.protobuf.ByteString) ref;
        }
      }
      /**
       * <code>string catalog = 5;</code>
       * @param value The catalog to set.
       * @return This builder for chaining.
       */
      public Builder setCatalog(
          java.lang.String value) {
        if (value == null) {
    throw new NullPointerException();
  }
  
        catalog_ = value;
        onChanged();
        return this;
      }
      /**
       * <code>string catalog = 5;</code>
       * @return This builder for chaining.
       */
      public Builder clearCatalog() {
        
        catalog_ = getDefaultInstance().getCatalog();
        onChanged();
        return this;
      }
      /**
       * <code>string catalog = 5;</code>
       * @param value The bytes for catalog to set.
       * @return This builder for chaining.
       */
      public Builder setCatalogBytes(
          com.google.protobuf.ByteString value) {
        if (value == null) {
    throw new NullPointerException();
  }
  checkByteStringIsUtf8(value);
        
        catalog_ = value;
        onChanged();
        return this;
      }

      private java.lang.Object schema_ = "";
      /**
       * <code>string schema = 6;</code>
       * @return The schema.
       */
      public java.lang.String getSchema() {
        java.lang.Object ref = schema_;
        if (!(ref instanceof java.lang.String)) {
          com.google.protobuf.ByteString bs =
              (com.google.protobuf.ByteString) ref;
          java.lang.String s = bs.toStringUtf8();
          schema_ = s;
          return s;
        } else {
          return (java.lang.String) ref;
        }
      }
      /**
       * <code>string schema = 6;</code>
       * @return The bytes for schema.
       */
      public com.google.protobuf.ByteString
          getSchemaBytes() {
        java.lang.Object ref = schema_;
        if (ref instanceof String) {
          com.google.protobuf.ByteString b = 
              com.google.protobuf.ByteString.copyFromUtf8(
                  (java.lang.String) ref);
          schema_ = b;
          return b;
        } else {
          return (com.google.protobuf.ByteString) ref;
        }
      }
      /**
       * <code>string schema = 6;</code>
       * @param value The schema to set.
       * @return This builder for chaining.
       */
      public Builder setSchema(
          java.lang.String value) {
        if (value == null) {
    throw new NullPointerException();
  }
  
        schema_ = value;
        onChanged();
        return this;
      }
      /**
       * <code>string schema = 6;</code>
       * @return This builder for chaining.
       */
      public Builder clearSchema() {
        
        schema_ = getDefaultInstance().getSchema();
        onChanged();
        return this;
      }
      /**
       * <code>string schema = 6;</code>
       * @param value The bytes for schema to set.
       * @return This builder for chaining.
       */
      public Builder setSchemaBytes(
          com.google.protobuf.ByteString value) {
        if (value == null) {
    throw new NullPointerException();
  }
  checkByteStringIsUtf8(value);
        
        schema_ = value;
        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:ConnectionProperties)
    }

    // @@protoc_insertion_point(class_scope:ConnectionProperties)
    private static final org.apache.calcite.avatica.proto.Common.ConnectionProperties DEFAULT_INSTANCE;
    static {
      DEFAULT_INSTANCE = new org.apache.calcite.avatica.proto.Common.ConnectionProperties();
    }

    public static org.apache.calcite.avatica.proto.Common.ConnectionProperties getDefaultInstance() {
      return DEFAULT_INSTANCE;
    }

    private static final com.google.protobuf.Parser<ConnectionProperties>
        PARSER = new com.google.protobuf.AbstractParser<ConnectionProperties>() {
      @java.lang.Override
      public ConnectionProperties 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<ConnectionProperties> parser() {
      return PARSER;
    }

    @java.lang.Override
    public com.google.protobuf.Parser<ConnectionProperties> getParserForType() {
      return PARSER;
    }

    @java.lang.Override
    public org.apache.calcite.avatica.proto.Common.ConnectionProperties getDefaultInstanceForType() {
      return DEFAULT_INSTANCE;
    }

  }

  public interface StatementHandleOrBuilder extends
      // @@protoc_insertion_point(interface_extends:StatementHandle)
      com.google.protobuf.MessageOrBuilder {

    /**
     * <code>string connection_id = 1;</code>
     * @return The connectionId.
     */
    java.lang.String getConnectionId();
    /**
     * <code>string connection_id = 1;</code>
     * @return The bytes for connectionId.
     */
    com.google.protobuf.ByteString
        getConnectionIdBytes();

    /**
     * <code>uint32 id = 2;</code>
     * @return The id.
     */
    int getId();

    /**
     * <code>.Signature signature = 3;</code>
     * @return Whether the signature field is set.
     */
    boolean hasSignature();
    /**
     * <code>.Signature signature = 3;</code>
     * @return The signature.
     */
    org.apache.calcite.avatica.proto.Common.Signature getSignature();
    /**
     * <code>.Signature signature = 3;</code>
     */
    org.apache.calcite.avatica.proto.Common.SignatureOrBuilder getSignatureOrBuilder();
  }
  /**
   * <pre>
   * Statement handle
   * </pre>
   *
   * Protobuf type {@code StatementHandle}
   */
  public static final class StatementHandle extends
      com.google.protobuf.GeneratedMessageV3 implements
      // @@protoc_insertion_point(message_implements:StatementHandle)
      StatementHandleOrBuilder {
  private static final long serialVersionUID = 0L;
    // Use StatementHandle.newBuilder() to construct.
    private StatementHandle(com.google.protobuf.GeneratedMessageV3.Builder<?> builder) {
      super(builder);
    }
    private StatementHandle() {
      connectionId_ = "";
    }

    @java.lang.Override
    @SuppressWarnings({"unused"})
    protected java.lang.Object newInstance(
        UnusedPrivateParameter unused) {
      return new StatementHandle();
    }

    @java.lang.Override
    public final com.google.protobuf.UnknownFieldSet
    getUnknownFields() {
      return this.unknownFields;
    }
    public static final com.google.protobuf.Descriptors.Descriptor
        getDescriptor() {
      return org.apache.calcite.avatica.proto.Common.internal_static_StatementHandle_descriptor;
    }

    @java.lang.Override
    protected com.google.protobuf.GeneratedMessageV3.FieldAccessorTable
        internalGetFieldAccessorTable() {
      return org.apache.calcite.avatica.proto.Common.internal_static_StatementHandle_fieldAccessorTable
          .ensureFieldAccessorsInitialized(
              org.apache.calcite.avatica.proto.Common.StatementHandle.class, org.apache.calcite.avatica.proto.Common.StatementHandle.Builder.class);
    }

    public static final int CONNECTION_ID_FIELD_NUMBER = 1;
    private volatile java.lang.Object connectionId_;
    /**
     * <code>string connection_id = 1;</code>
     * @return The connectionId.
     */
    @java.lang.Override
    public java.lang.String getConnectionId() {
      java.lang.Object ref = connectionId_;
      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();
        connectionId_ = s;
        return s;
      }
    }
    /**
     * <code>string connection_id = 1;</code>
     * @return The bytes for connectionId.
     */
    @java.lang.Override
    public com.google.protobuf.ByteString
        getConnectionIdBytes() {
      java.lang.Object ref = connectionId_;
      if (ref instanceof java.lang.String) {
        com.google.protobuf.ByteString b = 
            com.google.protobuf.ByteString.copyFromUtf8(
                (java.lang.String) ref);
        connectionId_ = b;
        return b;
      } else {
        return (com.google.protobuf.ByteString) ref;
      }
    }

    public static final int ID_FIELD_NUMBER = 2;
    private int id_;
    /**
     * <code>uint32 id = 2;</code>
     * @return The id.
     */
    @java.lang.Override
    public int getId() {
      return id_;
    }

    public static final int SIGNATURE_FIELD_NUMBER = 3;
    private org.apache.calcite.avatica.proto.Common.Signature signature_;
    /**
     * <code>.Signature signature = 3;</code>
     * @return Whether the signature field is set.
     */
    @java.lang.Override
    public boolean hasSignature() {
      return signature_ != null;
    }
    /**
     * <code>.Signature signature = 3;</code>
     * @return The signature.
     */
    @java.lang.Override
    public org.apache.calcite.avatica.proto.Common.Signature getSignature() {
      return signature_ == null ? org.apache.calcite.avatica.proto.Common.Signature.getDefaultInstance() : signature_;
    }
    /**
     * <code>.Signature signature = 3;</code>
     */
    @java.lang.Override
    public org.apache.calcite.avatica.proto.Common.SignatureOrBuilder getSignatureOrBuilder() {
      return getSignature();
    }

    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 (!com.google.protobuf.GeneratedMessageV3.isStringEmpty(connectionId_)) {
        com.google.protobuf.GeneratedMessageV3.writeString(output, 1, connectionId_);
      }
      if (id_ != 0) {
        output.writeUInt32(2, id_);
      }
      if (signature_ != null) {
        output.writeMessage(3, getSignature());
      }
      getUnknownFields().writeTo(output);
    }

    @java.lang.Override
    public int getSerializedSize() {
      int size = memoizedSize;
      if (size != -1) return size;

      size = 0;
      if (!com.google.protobuf.GeneratedMessageV3.isStringEmpty(connectionId_)) {
        size += com.google.protobuf.GeneratedMessageV3.computeStringSize(1, connectionId_);
      }
      if (id_ != 0) {
        size += com.google.protobuf.CodedOutputStream
          .computeUInt32Size(2, id_);
      }
      if (signature_ != null) {
        size += com.google.protobuf.CodedOutputStream
          .computeMessageSize(3, getSignature());
      }
      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 org.apache.calcite.avatica.proto.Common.StatementHandle)) {
        return super.equals(obj);
      }
      org.apache.calcite.avatica.proto.Common.StatementHandle other = (org.apache.calcite.avatica.proto.Common.StatementHandle) obj;

      if (!getConnectionId()
          .equals(other.getConnectionId())) return false;
      if (getId()
          != other.getId()) return false;
      if (hasSignature() != other.hasSignature()) return false;
      if (hasSignature()) {
        if (!getSignature()
            .equals(other.getSignature())) 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();
      hash = (37 * hash) + CONNECTION_ID_FIELD_NUMBER;
      hash = (53 * hash) + getConnectionId().hashCode();
      hash = (37 * hash) + ID_FIELD_NUMBER;
      hash = (53 * hash) + getId();
      if (hasSignature()) {
        hash = (37 * hash) + SIGNATURE_FIELD_NUMBER;
        hash = (53 * hash) + getSignature().hashCode();
      }
      hash = (29 * hash) + getUnknownFields().hashCode();
      memoizedHashCode = hash;
      return hash;
    }

    public static org.apache.calcite.avatica.proto.Common.StatementHandle parseFrom(
        java.nio.ByteBuffer data)
        throws com.google.protobuf.InvalidProtocolBufferException {
      return PARSER.parseFrom(data);
    }
    public static org.apache.calcite.avatica.proto.Common.StatementHandle parseFrom(
        java.nio.ByteBuffer data,
        com.google.protobuf.ExtensionRegistryLite extensionRegistry)
        throws com.google.protobuf.InvalidProtocolBufferException {
      return PARSER.parseFrom(data, extensionRegistry);
    }
    public static org.apache.calcite.avatica.proto.Common.StatementHandle parseFrom(
        com.google.protobuf.ByteString data)
        throws com.google.protobuf.InvalidProtocolBufferException {
      return PARSER.parseFrom(data);
    }
    public static org.apache.calcite.avatica.proto.Common.StatementHandle parseFrom(
        com.google.protobuf.ByteString data,
        com.google.protobuf.ExtensionRegistryLite extensionRegistry)
        throws com.google.protobuf.InvalidProtocolBufferException {
      return PARSER.parseFrom(data, extensionRegistry);
    }
    public static org.apache.calcite.avatica.proto.Common.StatementHandle parseFrom(byte[] data)
        throws com.google.protobuf.InvalidProtocolBufferException {
      return PARSER.parseFrom(data);
    }
    public static org.apache.calcite.avatica.proto.Common.StatementHandle parseFrom(
        byte[] data,
        com.google.protobuf.ExtensionRegistryLite extensionRegistry)
        throws com.google.protobuf.InvalidProtocolBufferException {
      return PARSER.parseFrom(data, extensionRegistry);
    }
    public static org.apache.calcite.avatica.proto.Common.StatementHandle parseFrom(java.io.InputStream input)
        throws java.io.IOException {
      return com.google.protobuf.GeneratedMessageV3
          .parseWithIOException(PARSER, input);
    }
    public static org.apache.calcite.avatica.proto.Common.StatementHandle 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 org.apache.calcite.avatica.proto.Common.StatementHandle parseDelimitedFrom(java.io.InputStream input)
        throws java.io.IOException {
      return com.google.protobuf.GeneratedMessageV3
          .parseDelimitedWithIOException(PARSER, input);
    }
    public static org.apache.calcite.avatica.proto.Common.StatementHandle 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 org.apache.calcite.avatica.proto.Common.StatementHandle parseFrom(
        com.google.protobuf.CodedInputStream input)
        throws java.io.IOException {
      return com.google.protobuf.GeneratedMessageV3
          .parseWithIOException(PARSER, input);
    }
    public static org.apache.calcite.avatica.proto.Common.StatementHandle 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(org.apache.calcite.avatica.proto.Common.StatementHandle 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;
    }
    /**
     * <pre>
     * Statement handle
     * </pre>
     *
     * Protobuf type {@code StatementHandle}
     */
    public static final class Builder extends
        com.google.protobuf.GeneratedMessageV3.Builder<Builder> implements
        // @@protoc_insertion_point(builder_implements:StatementHandle)
        org.apache.calcite.avatica.proto.Common.StatementHandleOrBuilder {
      public static final com.google.protobuf.Descriptors.Descriptor
          getDescriptor() {
        return org.apache.calcite.avatica.proto.Common.internal_static_StatementHandle_descriptor;
      }

      @java.lang.Override
      protected com.google.protobuf.GeneratedMessageV3.FieldAccessorTable
          internalGetFieldAccessorTable() {
        return org.apache.calcite.avatica.proto.Common.internal_static_StatementHandle_fieldAccessorTable
            .ensureFieldAccessorsInitialized(
                org.apache.calcite.avatica.proto.Common.StatementHandle.class, org.apache.calcite.avatica.proto.Common.StatementHandle.Builder.class);
      }

      // Construct using org.apache.calcite.avatica.proto.Common.StatementHandle.newBuilder()
      private Builder() {

      }

      private Builder(
          com.google.protobuf.GeneratedMessageV3.BuilderParent parent) {
        super(parent);

      }
      @java.lang.Override
      public Builder clear() {
        super.clear();
        connectionId_ = "";

        id_ = 0;

        if (signatureBuilder_ == null) {
          signature_ = null;
        } else {
          signature_ = null;
          signatureBuilder_ = null;
        }
        return this;
      }

      @java.lang.Override
      public com.google.protobuf.Descriptors.Descriptor
          getDescriptorForType() {
        return org.apache.calcite.avatica.proto.Common.internal_static_StatementHandle_descriptor;
      }

      @java.lang.Override
      public org.apache.calcite.avatica.proto.Common.StatementHandle getDefaultInstanceForType() {
        return org.apache.calcite.avatica.proto.Common.StatementHandle.getDefaultInstance();
      }

      @java.lang.Override
      public org.apache.calcite.avatica.proto.Common.StatementHandle build() {
        org.apache.calcite.avatica.proto.Common.StatementHandle result = buildPartial();
        if (!result.isInitialized()) {
          throw newUninitializedMessageException(result);
        }
        return result;
      }

      @java.lang.Override
      public org.apache.calcite.avatica.proto.Common.StatementHandle buildPartial() {
        org.apache.calcite.avatica.proto.Common.StatementHandle result = new org.apache.calcite.avatica.proto.Common.StatementHandle(this);
        result.connectionId_ = connectionId_;
        result.id_ = id_;
        if (signatureBuilder_ == null) {
          result.signature_ = signature_;
        } else {
          result.signature_ = signatureBuilder_.build();
        }
        onBuilt();
        return result;
      }

      @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 org.apache.calcite.avatica.proto.Common.StatementHandle) {
          return mergeFrom((org.apache.calcite.avatica.proto.Common.StatementHandle)other);
        } else {
          super.mergeFrom(other);
          return this;
        }
      }

      public Builder mergeFrom(org.apache.calcite.avatica.proto.Common.StatementHandle other) {
        if (other == org.apache.calcite.avatica.proto.Common.StatementHandle.getDefaultInstance()) return this;
        if (!other.getConnectionId().isEmpty()) {
          connectionId_ = other.connectionId_;
          onChanged();
        }
        if (other.getId() != 0) {
          setId(other.getId());
        }
        if (other.hasSignature()) {
          mergeSignature(other.getSignature());
        }
        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: {
                connectionId_ = input.readStringRequireUtf8();

                break;
              } // case 10
              case 16: {
                id_ = input.readUInt32();

                break;
              } // case 16
              case 26: {
                input.readMessage(
                    getSignatureFieldBuilder().getBuilder(),
                    extensionRegistry);

                break;
              } // case 26
              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 java.lang.Object connectionId_ = "";
      /**
       * <code>string connection_id = 1;</code>
       * @return The connectionId.
       */
      public java.lang.String getConnectionId() {
        java.lang.Object ref = connectionId_;
        if (!(ref instanceof java.lang.String)) {
          com.google.protobuf.ByteString bs =
              (com.google.protobuf.ByteString) ref;
          java.lang.String s = bs.toStringUtf8();
          connectionId_ = s;
          return s;
        } else {
          return (java.lang.String) ref;
        }
      }
      /**
       * <code>string connection_id = 1;</code>
       * @return The bytes for connectionId.
       */
      public com.google.protobuf.ByteString
          getConnectionIdBytes() {
        java.lang.Object ref = connectionId_;
        if (ref instanceof String) {
          com.google.protobuf.ByteString b = 
              com.google.protobuf.ByteString.copyFromUtf8(
                  (java.lang.String) ref);
          connectionId_ = b;
          return b;
        } else {
          return (com.google.protobuf.ByteString) ref;
        }
      }
      /**
       * <code>string connection_id = 1;</code>
       * @param value The connectionId to set.
       * @return This builder for chaining.
       */
      public Builder setConnectionId(
          java.lang.String value) {
        if (value == null) {
    throw new NullPointerException();
  }
  
        connectionId_ = value;
        onChanged();
        return this;
      }
      /**
       * <code>string connection_id = 1;</code>
       * @return This builder for chaining.
       */
      public Builder clearConnectionId() {
        
        connectionId_ = getDefaultInstance().getConnectionId();
        onChanged();
        return this;
      }
      /**
       * <code>string connection_id = 1;</code>
       * @param value The bytes for connectionId to set.
       * @return This builder for chaining.
       */
      public Builder setConnectionIdBytes(
          com.google.protobuf.ByteString value) {
        if (value == null) {
    throw new NullPointerException();
  }
  checkByteStringIsUtf8(value);
        
        connectionId_ = value;
        onChanged();
        return this;
      }

      private int id_ ;
      /**
       * <code>uint32 id = 2;</code>
       * @return The id.
       */
      @java.lang.Override
      public int getId() {
        return id_;
      }
      /**
       * <code>uint32 id = 2;</code>
       * @param value The id to set.
       * @return This builder for chaining.
       */
      public Builder setId(int value) {
        
        id_ = value;
        onChanged();
        return this;
      }
      /**
       * <code>uint32 id = 2;</code>
       * @return This builder for chaining.
       */
      public Builder clearId() {
        
        id_ = 0;
        onChanged();
        return this;
      }

      private org.apache.calcite.avatica.proto.Common.Signature signature_;
      private com.google.protobuf.SingleFieldBuilderV3<
          org.apache.calcite.avatica.proto.Common.Signature, org.apache.calcite.avatica.proto.Common.Signature.Builder, org.apache.calcite.avatica.proto.Common.SignatureOrBuilder> signatureBuilder_;
      /**
       * <code>.Signature signature = 3;</code>
       * @return Whether the signature field is set.
       */
      public boolean hasSignature() {
        return signatureBuilder_ != null || signature_ != null;
      }
      /**
       * <code>.Signature signature = 3;</code>
       * @return The signature.
       */
      public org.apache.calcite.avatica.proto.Common.Signature getSignature() {
        if (signatureBuilder_ == null) {
          return signature_ == null ? org.apache.calcite.avatica.proto.Common.Signature.getDefaultInstance() : signature_;
        } else {
          return signatureBuilder_.getMessage();
        }
      }
      /**
       * <code>.Signature signature = 3;</code>
       */
      public Builder setSignature(org.apache.calcite.avatica.proto.Common.Signature value) {
        if (signatureBuilder_ == null) {
          if (value == null) {
            throw new NullPointerException();
          }
          signature_ = value;
          onChanged();
        } else {
          signatureBuilder_.setMessage(value);
        }

        return this;
      }
      /**
       * <code>.Signature signature = 3;</code>
       */
      public Builder setSignature(
          org.apache.calcite.avatica.proto.Common.Signature.Builder builderForValue) {
        if (signatureBuilder_ == null) {
          signature_ = builderForValue.build();
          onChanged();
        } else {
          signatureBuilder_.setMessage(builderForValue.build());
        }

        return this;
      }
      /**
       * <code>.Signature signature = 3;</code>
       */
      public Builder mergeSignature(org.apache.calcite.avatica.proto.Common.Signature value) {
        if (signatureBuilder_ == null) {
          if (signature_ != null) {
            signature_ =
              org.apache.calcite.avatica.proto.Common.Signature.newBuilder(signature_).mergeFrom(value).buildPartial();
          } else {
            signature_ = value;
          }
          onChanged();
        } else {
          signatureBuilder_.mergeFrom(value);
        }

        return this;
      }
      /**
       * <code>.Signature signature = 3;</code>
       */
      public Builder clearSignature() {
        if (signatureBuilder_ == null) {
          signature_ = null;
          onChanged();
        } else {
          signature_ = null;
          signatureBuilder_ = null;
        }

        return this;
      }
      /**
       * <code>.Signature signature = 3;</code>
       */
      public org.apache.calcite.avatica.proto.Common.Signature.Builder getSignatureBuilder() {
        
        onChanged();
        return getSignatureFieldBuilder().getBuilder();
      }
      /**
       * <code>.Signature signature = 3;</code>
       */
      public org.apache.calcite.avatica.proto.Common.SignatureOrBuilder getSignatureOrBuilder() {
        if (signatureBuilder_ != null) {
          return signatureBuilder_.getMessageOrBuilder();
        } else {
          return signature_ == null ?
              org.apache.calcite.avatica.proto.Common.Signature.getDefaultInstance() : signature_;
        }
      }
      /**
       * <code>.Signature signature = 3;</code>
       */
      private com.google.protobuf.SingleFieldBuilderV3<
          org.apache.calcite.avatica.proto.Common.Signature, org.apache.calcite.avatica.proto.Common.Signature.Builder, org.apache.calcite.avatica.proto.Common.SignatureOrBuilder> 
          getSignatureFieldBuilder() {
        if (signatureBuilder_ == null) {
          signatureBuilder_ = new com.google.protobuf.SingleFieldBuilderV3<
              org.apache.calcite.avatica.proto.Common.Signature, org.apache.calcite.avatica.proto.Common.Signature.Builder, org.apache.calcite.avatica.proto.Common.SignatureOrBuilder>(
                  getSignature(),
                  getParentForChildren(),
                  isClean());
          signature_ = null;
        }
        return signatureBuilder_;
      }
      @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:StatementHandle)
    }

    // @@protoc_insertion_point(class_scope:StatementHandle)
    private static final org.apache.calcite.avatica.proto.Common.StatementHandle DEFAULT_INSTANCE;
    static {
      DEFAULT_INSTANCE = new org.apache.calcite.avatica.proto.Common.StatementHandle();
    }

    public static org.apache.calcite.avatica.proto.Common.StatementHandle getDefaultInstance() {
      return DEFAULT_INSTANCE;
    }

    private static final com.google.protobuf.Parser<StatementHandle>
        PARSER = new com.google.protobuf.AbstractParser<StatementHandle>() {
      @java.lang.Override
      public StatementHandle 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<StatementHandle> parser() {
      return PARSER;
    }

    @java.lang.Override
    public com.google.protobuf.Parser<StatementHandle> getParserForType() {
      return PARSER;
    }

    @java.lang.Override
    public org.apache.calcite.avatica.proto.Common.StatementHandle getDefaultInstanceForType() {
      return DEFAULT_INSTANCE;
    }

  }

  public interface SignatureOrBuilder extends
      // @@protoc_insertion_point(interface_extends:Signature)
      com.google.protobuf.MessageOrBuilder {

    /**
     * <code>repeated .ColumnMetaData columns = 1;</code>
     */
    java.util.List<org.apache.calcite.avatica.proto.Common.ColumnMetaData> 
        getColumnsList();
    /**
     * <code>repeated .ColumnMetaData columns = 1;</code>
     */
    org.apache.calcite.avatica.proto.Common.ColumnMetaData getColumns(int index);
    /**
     * <code>repeated .ColumnMetaData columns = 1;</code>
     */
    int getColumnsCount();
    /**
     * <code>repeated .ColumnMetaData columns = 1;</code>
     */
    java.util.List<? extends org.apache.calcite.avatica.proto.Common.ColumnMetaDataOrBuilder> 
        getColumnsOrBuilderList();
    /**
     * <code>repeated .ColumnMetaData columns = 1;</code>
     */
    org.apache.calcite.avatica.proto.Common.ColumnMetaDataOrBuilder getColumnsOrBuilder(
        int index);

    /**
     * <code>string sql = 2;</code>
     * @return The sql.
     */
    java.lang.String getSql();
    /**
     * <code>string sql = 2;</code>
     * @return The bytes for sql.
     */
    com.google.protobuf.ByteString
        getSqlBytes();

    /**
     * <code>repeated .AvaticaParameter parameters = 3;</code>
     */
    java.util.List<org.apache.calcite.avatica.proto.Common.AvaticaParameter> 
        getParametersList();
    /**
     * <code>repeated .AvaticaParameter parameters = 3;</code>
     */
    org.apache.calcite.avatica.proto.Common.AvaticaParameter getParameters(int index);
    /**
     * <code>repeated .AvaticaParameter parameters = 3;</code>
     */
    int getParametersCount();
    /**
     * <code>repeated .AvaticaParameter parameters = 3;</code>
     */
    java.util.List<? extends org.apache.calcite.avatica.proto.Common.AvaticaParameterOrBuilder> 
        getParametersOrBuilderList();
    /**
     * <code>repeated .AvaticaParameter parameters = 3;</code>
     */
    org.apache.calcite.avatica.proto.Common.AvaticaParameterOrBuilder getParametersOrBuilder(
        int index);

    /**
     * <code>.CursorFactory cursor_factory = 4;</code>
     * @return Whether the cursorFactory field is set.
     */
    boolean hasCursorFactory();
    /**
     * <code>.CursorFactory cursor_factory = 4;</code>
     * @return The cursorFactory.
     */
    org.apache.calcite.avatica.proto.Common.CursorFactory getCursorFactory();
    /**
     * <code>.CursorFactory cursor_factory = 4;</code>
     */
    org.apache.calcite.avatica.proto.Common.CursorFactoryOrBuilder getCursorFactoryOrBuilder();

    /**
     * <code>.StatementType statementType = 5;</code>
     * @return The enum numeric value on the wire for statementType.
     */
    int getStatementTypeValue();
    /**
     * <code>.StatementType statementType = 5;</code>
     * @return The statementType.
     */
    org.apache.calcite.avatica.proto.Common.StatementType getStatementType();
  }
  /**
   * <pre>
   * Results of preparing a statement
   * </pre>
   *
   * Protobuf type {@code Signature}
   */
  public static final class Signature extends
      com.google.protobuf.GeneratedMessageV3 implements
      // @@protoc_insertion_point(message_implements:Signature)
      SignatureOrBuilder {
  private static final long serialVersionUID = 0L;
    // Use Signature.newBuilder() to construct.
    private Signature(com.google.protobuf.GeneratedMessageV3.Builder<?> builder) {
      super(builder);
    }
    private Signature() {
      columns_ = java.util.Collections.emptyList();
      sql_ = "";
      parameters_ = java.util.Collections.emptyList();
      statementType_ = 0;
    }

    @java.lang.Override
    @SuppressWarnings({"unused"})
    protected java.lang.Object newInstance(
        UnusedPrivateParameter unused) {
      return new Signature();
    }

    @java.lang.Override
    public final com.google.protobuf.UnknownFieldSet
    getUnknownFields() {
      return this.unknownFields;
    }
    public static final com.google.protobuf.Descriptors.Descriptor
        getDescriptor() {
      return org.apache.calcite.avatica.proto.Common.internal_static_Signature_descriptor;
    }

    @java.lang.Override
    protected com.google.protobuf.GeneratedMessageV3.FieldAccessorTable
        internalGetFieldAccessorTable() {
      return org.apache.calcite.avatica.proto.Common.internal_static_Signature_fieldAccessorTable
          .ensureFieldAccessorsInitialized(
              org.apache.calcite.avatica.proto.Common.Signature.class, org.apache.calcite.avatica.proto.Common.Signature.Builder.class);
    }

    public static final int COLUMNS_FIELD_NUMBER = 1;
    private java.util.List<org.apache.calcite.avatica.proto.Common.ColumnMetaData> columns_;
    /**
     * <code>repeated .ColumnMetaData columns = 1;</code>
     */
    @java.lang.Override
    public java.util.List<org.apache.calcite.avatica.proto.Common.ColumnMetaData> getColumnsList() {
      return columns_;
    }
    /**
     * <code>repeated .ColumnMetaData columns = 1;</code>
     */
    @java.lang.Override
    public java.util.List<? extends org.apache.calcite.avatica.proto.Common.ColumnMetaDataOrBuilder> 
        getColumnsOrBuilderList() {
      return columns_;
    }
    /**
     * <code>repeated .ColumnMetaData columns = 1;</code>
     */
    @java.lang.Override
    public int getColumnsCount() {
      return columns_.size();
    }
    /**
     * <code>repeated .ColumnMetaData columns = 1;</code>
     */
    @java.lang.Override
    public org.apache.calcite.avatica.proto.Common.ColumnMetaData getColumns(int index) {
      return columns_.get(index);
    }
    /**
     * <code>repeated .ColumnMetaData columns = 1;</code>
     */
    @java.lang.Override
    public org.apache.calcite.avatica.proto.Common.ColumnMetaDataOrBuilder getColumnsOrBuilder(
        int index) {
      return columns_.get(index);
    }

    public static final int SQL_FIELD_NUMBER = 2;
    private volatile java.lang.Object sql_;
    /**
     * <code>string sql = 2;</code>
     * @return The sql.
     */
    @java.lang.Override
    public java.lang.String getSql() {
      java.lang.Object ref = sql_;
      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();
        sql_ = s;
        return s;
      }
    }
    /**
     * <code>string sql = 2;</code>
     * @return The bytes for sql.
     */
    @java.lang.Override
    public com.google.protobuf.ByteString
        getSqlBytes() {
      java.lang.Object ref = sql_;
      if (ref instanceof java.lang.String) {
        com.google.protobuf.ByteString b = 
            com.google.protobuf.ByteString.copyFromUtf8(
                (java.lang.String) ref);
        sql_ = b;
        return b;
      } else {
        return (com.google.protobuf.ByteString) ref;
      }
    }

    public static final int PARAMETERS_FIELD_NUMBER = 3;
    private java.util.List<org.apache.calcite.avatica.proto.Common.AvaticaParameter> parameters_;
    /**
     * <code>repeated .AvaticaParameter parameters = 3;</code>
     */
    @java.lang.Override
    public java.util.List<org.apache.calcite.avatica.proto.Common.AvaticaParameter> getParametersList() {
      return parameters_;
    }
    /**
     * <code>repeated .AvaticaParameter parameters = 3;</code>
     */
    @java.lang.Override
    public java.util.List<? extends org.apache.calcite.avatica.proto.Common.AvaticaParameterOrBuilder> 
        getParametersOrBuilderList() {
      return parameters_;
    }
    /**
     * <code>repeated .AvaticaParameter parameters = 3;</code>
     */
    @java.lang.Override
    public int getParametersCount() {
      return parameters_.size();
    }
    /**
     * <code>repeated .AvaticaParameter parameters = 3;</code>
     */
    @java.lang.Override
    public org.apache.calcite.avatica.proto.Common.AvaticaParameter getParameters(int index) {
      return parameters_.get(index);
    }
    /**
     * <code>repeated .AvaticaParameter parameters = 3;</code>
     */
    @java.lang.Override
    public org.apache.calcite.avatica.proto.Common.AvaticaParameterOrBuilder getParametersOrBuilder(
        int index) {
      return parameters_.get(index);
    }

    public static final int CURSOR_FACTORY_FIELD_NUMBER = 4;
    private org.apache.calcite.avatica.proto.Common.CursorFactory cursorFactory_;
    /**
     * <code>.CursorFactory cursor_factory = 4;</code>
     * @return Whether the cursorFactory field is set.
     */
    @java.lang.Override
    public boolean hasCursorFactory() {
      return cursorFactory_ != null;
    }
    /**
     * <code>.CursorFactory cursor_factory = 4;</code>
     * @return The cursorFactory.
     */
    @java.lang.Override
    public org.apache.calcite.avatica.proto.Common.CursorFactory getCursorFactory() {
      return cursorFactory_ == null ? org.apache.calcite.avatica.proto.Common.CursorFactory.getDefaultInstance() : cursorFactory_;
    }
    /**
     * <code>.CursorFactory cursor_factory = 4;</code>
     */
    @java.lang.Override
    public org.apache.calcite.avatica.proto.Common.CursorFactoryOrBuilder getCursorFactoryOrBuilder() {
      return getCursorFactory();
    }

    public static final int STATEMENTTYPE_FIELD_NUMBER = 5;
    private int statementType_;
    /**
     * <code>.StatementType statementType = 5;</code>
     * @return The enum numeric value on the wire for statementType.
     */
    @java.lang.Override public int getStatementTypeValue() {
      return statementType_;
    }
    /**
     * <code>.StatementType statementType = 5;</code>
     * @return The statementType.
     */
    @java.lang.Override public org.apache.calcite.avatica.proto.Common.StatementType getStatementType() {
      @SuppressWarnings("deprecation")
      org.apache.calcite.avatica.proto.Common.StatementType result = org.apache.calcite.avatica.proto.Common.StatementType.valueOf(statementType_);
      return result == null ? org.apache.calcite.avatica.proto.Common.StatementType.UNRECOGNIZED : result;
    }

    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 {
      for (int i = 0; i < columns_.size(); i++) {
        output.writeMessage(1, columns_.get(i));
      }
      if (!com.google.protobuf.GeneratedMessageV3.isStringEmpty(sql_)) {
        com.google.protobuf.GeneratedMessageV3.writeString(output, 2, sql_);
      }
      for (int i = 0; i < parameters_.size(); i++) {
        output.writeMessage(3, parameters_.get(i));
      }
      if (cursorFactory_ != null) {
        output.writeMessage(4, getCursorFactory());
      }
      if (statementType_ != org.apache.calcite.avatica.proto.Common.StatementType.SELECT.getNumber()) {
        output.writeEnum(5, statementType_);
      }
      getUnknownFields().writeTo(output);
    }

    @java.lang.Override
    public int getSerializedSize() {
      int size = memoizedSize;
      if (size != -1) return size;

      size = 0;
      for (int i = 0; i < columns_.size(); i++) {
        size += com.google.protobuf.CodedOutputStream
          .computeMessageSize(1, columns_.get(i));
      }
      if (!com.google.protobuf.GeneratedMessageV3.isStringEmpty(sql_)) {
        size += com.google.protobuf.GeneratedMessageV3.computeStringSize(2, sql_);
      }
      for (int i = 0; i < parameters_.size(); i++) {
        size += com.google.protobuf.CodedOutputStream
          .computeMessageSize(3, parameters_.get(i));
      }
      if (cursorFactory_ != null) {
        size += com.google.protobuf.CodedOutputStream
          .computeMessageSize(4, getCursorFactory());
      }
      if (statementType_ != org.apache.calcite.avatica.proto.Common.StatementType.SELECT.getNumber()) {
        size += com.google.protobuf.CodedOutputStream
          .computeEnumSize(5, statementType_);
      }
      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 org.apache.calcite.avatica.proto.Common.Signature)) {
        return super.equals(obj);
      }
      org.apache.calcite.avatica.proto.Common.Signature other = (org.apache.calcite.avatica.proto.Common.Signature) obj;

      if (!getColumnsList()
          .equals(other.getColumnsList())) return false;
      if (!getSql()
          .equals(other.getSql())) return false;
      if (!getParametersList()
          .equals(other.getParametersList())) return false;
      if (hasCursorFactory() != other.hasCursorFactory()) return false;
      if (hasCursorFactory()) {
        if (!getCursorFactory()
            .equals(other.getCursorFactory())) return false;
      }
      if (statementType_ != other.statementType_) 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 (getColumnsCount() > 0) {
        hash = (37 * hash) + COLUMNS_FIELD_NUMBER;
        hash = (53 * hash) + getColumnsList().hashCode();
      }
      hash = (37 * hash) + SQL_FIELD_NUMBER;
      hash = (53 * hash) + getSql().hashCode();
      if (getParametersCount() > 0) {
        hash = (37 * hash) + PARAMETERS_FIELD_NUMBER;
        hash = (53 * hash) + getParametersList().hashCode();
      }
      if (hasCursorFactory()) {
        hash = (37 * hash) + CURSOR_FACTORY_FIELD_NUMBER;
        hash = (53 * hash) + getCursorFactory().hashCode();
      }
      hash = (37 * hash) + STATEMENTTYPE_FIELD_NUMBER;
      hash = (53 * hash) + statementType_;
      hash = (29 * hash) + getUnknownFields().hashCode();
      memoizedHashCode = hash;
      return hash;
    }

    public static org.apache.calcite.avatica.proto.Common.Signature parseFrom(
        java.nio.ByteBuffer data)
        throws com.google.protobuf.InvalidProtocolBufferException {
      return PARSER.parseFrom(data);
    }
    public static org.apache.calcite.avatica.proto.Common.Signature parseFrom(
        java.nio.ByteBuffer data,
        com.google.protobuf.ExtensionRegistryLite extensionRegistry)
        throws com.google.protobuf.InvalidProtocolBufferException {
      return PARSER.parseFrom(data, extensionRegistry);
    }
    public static org.apache.calcite.avatica.proto.Common.Signature parseFrom(
        com.google.protobuf.ByteString data)
        throws com.google.protobuf.InvalidProtocolBufferException {
      return PARSER.parseFrom(data);
    }
    public static org.apache.calcite.avatica.proto.Common.Signature parseFrom(
        com.google.protobuf.ByteString data,
        com.google.protobuf.ExtensionRegistryLite extensionRegistry)
        throws com.google.protobuf.InvalidProtocolBufferException {
      return PARSER.parseFrom(data, extensionRegistry);
    }
    public static org.apache.calcite.avatica.proto.Common.Signature parseFrom(byte[] data)
        throws com.google.protobuf.InvalidProtocolBufferException {
      return PARSER.parseFrom(data);
    }
    public static org.apache.calcite.avatica.proto.Common.Signature parseFrom(
        byte[] data,
        com.google.protobuf.ExtensionRegistryLite extensionRegistry)
        throws com.google.protobuf.InvalidProtocolBufferException {
      return PARSER.parseFrom(data, extensionRegistry);
    }
    public static org.apache.calcite.avatica.proto.Common.Signature parseFrom(java.io.InputStream input)
        throws java.io.IOException {
      return com.google.protobuf.GeneratedMessageV3
          .parseWithIOException(PARSER, input);
    }
    public static org.apache.calcite.avatica.proto.Common.Signature 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 org.apache.calcite.avatica.proto.Common.Signature parseDelimitedFrom(java.io.InputStream input)
        throws java.io.IOException {
      return com.google.protobuf.GeneratedMessageV3
          .parseDelimitedWithIOException(PARSER, input);
    }
    public static org.apache.calcite.avatica.proto.Common.Signature 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 org.apache.calcite.avatica.proto.Common.Signature parseFrom(
        com.google.protobuf.CodedInputStream input)
        throws java.io.IOException {
      return com.google.protobuf.GeneratedMessageV3
          .parseWithIOException(PARSER, input);
    }
    public static org.apache.calcite.avatica.proto.Common.Signature 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(org.apache.calcite.avatica.proto.Common.Signature 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;
    }
    /**
     * <pre>
     * Results of preparing a statement
     * </pre>
     *
     * Protobuf type {@code Signature}
     */
    public static final class Builder extends
        com.google.protobuf.GeneratedMessageV3.Builder<Builder> implements
        // @@protoc_insertion_point(builder_implements:Signature)
        org.apache.calcite.avatica.proto.Common.SignatureOrBuilder {
      public static final com.google.protobuf.Descriptors.Descriptor
          getDescriptor() {
        return org.apache.calcite.avatica.proto.Common.internal_static_Signature_descriptor;
      }

      @java.lang.Override
      protected com.google.protobuf.GeneratedMessageV3.FieldAccessorTable
          internalGetFieldAccessorTable() {
        return org.apache.calcite.avatica.proto.Common.internal_static_Signature_fieldAccessorTable
            .ensureFieldAccessorsInitialized(
                org.apache.calcite.avatica.proto.Common.Signature.class, org.apache.calcite.avatica.proto.Common.Signature.Builder.class);
      }

      // Construct using org.apache.calcite.avatica.proto.Common.Signature.newBuilder()
      private Builder() {

      }

      private Builder(
          com.google.protobuf.GeneratedMessageV3.BuilderParent parent) {
        super(parent);

      }
      @java.lang.Override
      public Builder clear() {
        super.clear();
        if (columnsBuilder_ == null) {
          columns_ = java.util.Collections.emptyList();
        } else {
          columns_ = null;
          columnsBuilder_.clear();
        }
        bitField0_ = (bitField0_ & ~0x00000001);
        sql_ = "";

        if (parametersBuilder_ == null) {
          parameters_ = java.util.Collections.emptyList();
        } else {
          parameters_ = null;
          parametersBuilder_.clear();
        }
        bitField0_ = (bitField0_ & ~0x00000002);
        if (cursorFactoryBuilder_ == null) {
          cursorFactory_ = null;
        } else {
          cursorFactory_ = null;
          cursorFactoryBuilder_ = null;
        }
        statementType_ = 0;

        return this;
      }

      @java.lang.Override
      public com.google.protobuf.Descriptors.Descriptor
          getDescriptorForType() {
        return org.apache.calcite.avatica.proto.Common.internal_static_Signature_descriptor;
      }

      @java.lang.Override
      public org.apache.calcite.avatica.proto.Common.Signature getDefaultInstanceForType() {
        return org.apache.calcite.avatica.proto.Common.Signature.getDefaultInstance();
      }

      @java.lang.Override
      public org.apache.calcite.avatica.proto.Common.Signature build() {
        org.apache.calcite.avatica.proto.Common.Signature result = buildPartial();
        if (!result.isInitialized()) {
          throw newUninitializedMessageException(result);
        }
        return result;
      }

      @java.lang.Override
      public org.apache.calcite.avatica.proto.Common.Signature buildPartial() {
        org.apache.calcite.avatica.proto.Common.Signature result = new org.apache.calcite.avatica.proto.Common.Signature(this);
        int from_bitField0_ = bitField0_;
        if (columnsBuilder_ == null) {
          if (((bitField0_ & 0x00000001) != 0)) {
            columns_ = java.util.Collections.unmodifiableList(columns_);
            bitField0_ = (bitField0_ & ~0x00000001);
          }
          result.columns_ = columns_;
        } else {
          result.columns_ = columnsBuilder_.build();
        }
        result.sql_ = sql_;
        if (parametersBuilder_ == null) {
          if (((bitField0_ & 0x00000002) != 0)) {
            parameters_ = java.util.Collections.unmodifiableList(parameters_);
            bitField0_ = (bitField0_ & ~0x00000002);
          }
          result.parameters_ = parameters_;
        } else {
          result.parameters_ = parametersBuilder_.build();
        }
        if (cursorFactoryBuilder_ == null) {
          result.cursorFactory_ = cursorFactory_;
        } else {
          result.cursorFactory_ = cursorFactoryBuilder_.build();
        }
        result.statementType_ = statementType_;
        onBuilt();
        return result;
      }

      @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 org.apache.calcite.avatica.proto.Common.Signature) {
          return mergeFrom((org.apache.calcite.avatica.proto.Common.Signature)other);
        } else {
          super.mergeFrom(other);
          return this;
        }
      }

      public Builder mergeFrom(org.apache.calcite.avatica.proto.Common.Signature other) {
        if (other == org.apache.calcite.avatica.proto.Common.Signature.getDefaultInstance()) return this;
        if (columnsBuilder_ == null) {
          if (!other.columns_.isEmpty()) {
            if (columns_.isEmpty()) {
              columns_ = other.columns_;
              bitField0_ = (bitField0_ & ~0x00000001);
            } else {
              ensureColumnsIsMutable();
              columns_.addAll(other.columns_);
            }
            onChanged();
          }
        } else {
          if (!other.columns_.isEmpty()) {
            if (columnsBuilder_.isEmpty()) {
              columnsBuilder_.dispose();
              columnsBuilder_ = null;
              columns_ = other.columns_;
              bitField0_ = (bitField0_ & ~0x00000001);
              columnsBuilder_ = 
                com.google.protobuf.GeneratedMessageV3.alwaysUseFieldBuilders ?
                   getColumnsFieldBuilder() : null;
            } else {
              columnsBuilder_.addAllMessages(other.columns_);
            }
          }
        }
        if (!other.getSql().isEmpty()) {
          sql_ = other.sql_;
          onChanged();
        }
        if (parametersBuilder_ == null) {
          if (!other.parameters_.isEmpty()) {
            if (parameters_.isEmpty()) {
              parameters_ = other.parameters_;
              bitField0_ = (bitField0_ & ~0x00000002);
            } else {
              ensureParametersIsMutable();
              parameters_.addAll(other.parameters_);
            }
            onChanged();
          }
        } else {
          if (!other.parameters_.isEmpty()) {
            if (parametersBuilder_.isEmpty()) {
              parametersBuilder_.dispose();
              parametersBuilder_ = null;
              parameters_ = other.parameters_;
              bitField0_ = (bitField0_ & ~0x00000002);
              parametersBuilder_ = 
                com.google.protobuf.GeneratedMessageV3.alwaysUseFieldBuilders ?
                   getParametersFieldBuilder() : null;
            } else {
              parametersBuilder_.addAllMessages(other.parameters_);
            }
          }
        }
        if (other.hasCursorFactory()) {
          mergeCursorFactory(other.getCursorFactory());
        }
        if (other.statementType_ != 0) {
          setStatementTypeValue(other.getStatementTypeValue());
        }
        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: {
                org.apache.calcite.avatica.proto.Common.ColumnMetaData m =
                    input.readMessage(
                        org.apache.calcite.avatica.proto.Common.ColumnMetaData.parser(),
                        extensionRegistry);
                if (columnsBuilder_ == null) {
                  ensureColumnsIsMutable();
                  columns_.add(m);
                } else {
                  columnsBuilder_.addMessage(m);
                }
                break;
              } // case 10
              case 18: {
                sql_ = input.readStringRequireUtf8();

                break;
              } // case 18
              case 26: {
                org.apache.calcite.avatica.proto.Common.AvaticaParameter m =
                    input.readMessage(
                        org.apache.calcite.avatica.proto.Common.AvaticaParameter.parser(),
                        extensionRegistry);
                if (parametersBuilder_ == null) {
                  ensureParametersIsMutable();
                  parameters_.add(m);
                } else {
                  parametersBuilder_.addMessage(m);
                }
                break;
              } // case 26
              case 34: {
                input.readMessage(
                    getCursorFactoryFieldBuilder().getBuilder(),
                    extensionRegistry);

                break;
              } // case 34
              case 40: {
                statementType_ = input.readEnum();

                break;
              } // case 40
              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.util.List<org.apache.calcite.avatica.proto.Common.ColumnMetaData> columns_ =
        java.util.Collections.emptyList();
      private void ensureColumnsIsMutable() {
        if (!((bitField0_ & 0x00000001) != 0)) {
          columns_ = new java.util.ArrayList<org.apache.calcite.avatica.proto.Common.ColumnMetaData>(columns_);
          bitField0_ |= 0x00000001;
         }
      }

      private com.google.protobuf.RepeatedFieldBuilderV3<
          org.apache.calcite.avatica.proto.Common.ColumnMetaData, org.apache.calcite.avatica.proto.Common.ColumnMetaData.Builder, org.apache.calcite.avatica.proto.Common.ColumnMetaDataOrBuilder> columnsBuilder_;

      /**
       * <code>repeated .ColumnMetaData columns = 1;</code>
       */
      public java.util.List<org.apache.calcite.avatica.proto.Common.ColumnMetaData> getColumnsList() {
        if (columnsBuilder_ == null) {
          return java.util.Collections.unmodifiableList(columns_);
        } else {
          return columnsBuilder_.getMessageList();
        }
      }
      /**
       * <code>repeated .ColumnMetaData columns = 1;</code>
       */
      public int getColumnsCount() {
        if (columnsBuilder_ == null) {
          return columns_.size();
        } else {
          return columnsBuilder_.getCount();
        }
      }
      /**
       * <code>repeated .ColumnMetaData columns = 1;</code>
       */
      public org.apache.calcite.avatica.proto.Common.ColumnMetaData getColumns(int index) {
        if (columnsBuilder_ == null) {
          return columns_.get(index);
        } else {
          return columnsBuilder_.getMessage(index);
        }
      }
      /**
       * <code>repeated .ColumnMetaData columns = 1;</code>
       */
      public Builder setColumns(
          int index, org.apache.calcite.avatica.proto.Common.ColumnMetaData value) {
        if (columnsBuilder_ == null) {
          if (value == null) {
            throw new NullPointerException();
          }
          ensureColumnsIsMutable();
          columns_.set(index, value);
          onChanged();
        } else {
          columnsBuilder_.setMessage(index, value);
        }
        return this;
      }
      /**
       * <code>repeated .ColumnMetaData columns = 1;</code>
       */
      public Builder setColumns(
          int index, org.apache.calcite.avatica.proto.Common.ColumnMetaData.Builder builderForValue) {
        if (columnsBuilder_ == null) {
          ensureColumnsIsMutable();
          columns_.set(index, builderForValue.build());
          onChanged();
        } else {
          columnsBuilder_.setMessage(index, builderForValue.build());
        }
        return this;
      }
      /**
       * <code>repeated .ColumnMetaData columns = 1;</code>
       */
      public Builder addColumns(org.apache.calcite.avatica.proto.Common.ColumnMetaData value) {
        if (columnsBuilder_ == null) {
          if (value == null) {
            throw new NullPointerException();
          }
          ensureColumnsIsMutable();
          columns_.add(value);
          onChanged();
        } else {
          columnsBuilder_.addMessage(value);
        }
        return this;
      }
      /**
       * <code>repeated .ColumnMetaData columns = 1;</code>
       */
      public Builder addColumns(
          int index, org.apache.calcite.avatica.proto.Common.ColumnMetaData value) {
        if (columnsBuilder_ == null) {
          if (value == null) {
            throw new NullPointerException();
          }
          ensureColumnsIsMutable();
          columns_.add(index, value);
          onChanged();
        } else {
          columnsBuilder_.addMessage(index, value);
        }
        return this;
      }
      /**
       * <code>repeated .ColumnMetaData columns = 1;</code>
       */
      public Builder addColumns(
          org.apache.calcite.avatica.proto.Common.ColumnMetaData.Builder builderForValue) {
        if (columnsBuilder_ == null) {
          ensureColumnsIsMutable();
          columns_.add(builderForValue.build());
          onChanged();
        } else {
          columnsBuilder_.addMessage(builderForValue.build());
        }
        return this;
      }
      /**
       * <code>repeated .ColumnMetaData columns = 1;</code>
       */
      public Builder addColumns(
          int index, org.apache.calcite.avatica.proto.Common.ColumnMetaData.Builder builderForValue) {
        if (columnsBuilder_ == null) {
          ensureColumnsIsMutable();
          columns_.add(index, builderForValue.build());
          onChanged();
        } else {
          columnsBuilder_.addMessage(index, builderForValue.build());
        }
        return this;
      }
      /**
       * <code>repeated .ColumnMetaData columns = 1;</code>
       */
      public Builder addAllColumns(
          java.lang.Iterable<? extends org.apache.calcite.avatica.proto.Common.ColumnMetaData> values) {
        if (columnsBuilder_ == null) {
          ensureColumnsIsMutable();
          com.google.protobuf.AbstractMessageLite.Builder.addAll(
              values, columns_);
          onChanged();
        } else {
          columnsBuilder_.addAllMessages(values);
        }
        return this;
      }
      /**
       * <code>repeated .ColumnMetaData columns = 1;</code>
       */
      public Builder clearColumns() {
        if (columnsBuilder_ == null) {
          columns_ = java.util.Collections.emptyList();
          bitField0_ = (bitField0_ & ~0x00000001);
          onChanged();
        } else {
          columnsBuilder_.clear();
        }
        return this;
      }
      /**
       * <code>repeated .ColumnMetaData columns = 1;</code>
       */
      public Builder removeColumns(int index) {
        if (columnsBuilder_ == null) {
          ensureColumnsIsMutable();
          columns_.remove(index);
          onChanged();
        } else {
          columnsBuilder_.remove(index);
        }
        return this;
      }
      /**
       * <code>repeated .ColumnMetaData columns = 1;</code>
       */
      public org.apache.calcite.avatica.proto.Common.ColumnMetaData.Builder getColumnsBuilder(
          int index) {
        return getColumnsFieldBuilder().getBuilder(index);
      }
      /**
       * <code>repeated .ColumnMetaData columns = 1;</code>
       */
      public org.apache.calcite.avatica.proto.Common.ColumnMetaDataOrBuilder getColumnsOrBuilder(
          int index) {
        if (columnsBuilder_ == null) {
          return columns_.get(index);  } else {
          return columnsBuilder_.getMessageOrBuilder(index);
        }
      }
      /**
       * <code>repeated .ColumnMetaData columns = 1;</code>
       */
      public java.util.List<? extends org.apache.calcite.avatica.proto.Common.ColumnMetaDataOrBuilder> 
           getColumnsOrBuilderList() {
        if (columnsBuilder_ != null) {
          return columnsBuilder_.getMessageOrBuilderList();
        } else {
          return java.util.Collections.unmodifiableList(columns_);
        }
      }
      /**
       * <code>repeated .ColumnMetaData columns = 1;</code>
       */
      public org.apache.calcite.avatica.proto.Common.ColumnMetaData.Builder addColumnsBuilder() {
        return getColumnsFieldBuilder().addBuilder(
            org.apache.calcite.avatica.proto.Common.ColumnMetaData.getDefaultInstance());
      }
      /**
       * <code>repeated .ColumnMetaData columns = 1;</code>
       */
      public org.apache.calcite.avatica.proto.Common.ColumnMetaData.Builder addColumnsBuilder(
          int index) {
        return getColumnsFieldBuilder().addBuilder(
            index, org.apache.calcite.avatica.proto.Common.ColumnMetaData.getDefaultInstance());
      }
      /**
       * <code>repeated .ColumnMetaData columns = 1;</code>
       */
      public java.util.List<org.apache.calcite.avatica.proto.Common.ColumnMetaData.Builder> 
           getColumnsBuilderList() {
        return getColumnsFieldBuilder().getBuilderList();
      }
      private com.google.protobuf.RepeatedFieldBuilderV3<
          org.apache.calcite.avatica.proto.Common.ColumnMetaData, org.apache.calcite.avatica.proto.Common.ColumnMetaData.Builder, org.apache.calcite.avatica.proto.Common.ColumnMetaDataOrBuilder> 
          getColumnsFieldBuilder() {
        if (columnsBuilder_ == null) {
          columnsBuilder_ = new com.google.protobuf.RepeatedFieldBuilderV3<
              org.apache.calcite.avatica.proto.Common.ColumnMetaData, org.apache.calcite.avatica.proto.Common.ColumnMetaData.Builder, org.apache.calcite.avatica.proto.Common.ColumnMetaDataOrBuilder>(
                  columns_,
                  ((bitField0_ & 0x00000001) != 0),
                  getParentForChildren(),
                  isClean());
          columns_ = null;
        }
        return columnsBuilder_;
      }

      private java.lang.Object sql_ = "";
      /**
       * <code>string sql = 2;</code>
       * @return The sql.
       */
      public java.lang.String getSql() {
        java.lang.Object ref = sql_;
        if (!(ref instanceof java.lang.String)) {
          com.google.protobuf.ByteString bs =
              (com.google.protobuf.ByteString) ref;
          java.lang.String s = bs.toStringUtf8();
          sql_ = s;
          return s;
        } else {
          return (java.lang.String) ref;
        }
      }
      /**
       * <code>string sql = 2;</code>
       * @return The bytes for sql.
       */
      public com.google.protobuf.ByteString
          getSqlBytes() {
        java.lang.Object ref = sql_;
        if (ref instanceof String) {
          com.google.protobuf.ByteString b = 
              com.google.protobuf.ByteString.copyFromUtf8(
                  (java.lang.String) ref);
          sql_ = b;
          return b;
        } else {
          return (com.google.protobuf.ByteString) ref;
        }
      }
      /**
       * <code>string sql = 2;</code>
       * @param value The sql to set.
       * @return This builder for chaining.
       */
      public Builder setSql(
          java.lang.String value) {
        if (value == null) {
    throw new NullPointerException();
  }
  
        sql_ = value;
        onChanged();
        return this;
      }
      /**
       * <code>string sql = 2;</code>
       * @return This builder for chaining.
       */
      public Builder clearSql() {
        
        sql_ = getDefaultInstance().getSql();
        onChanged();
        return this;
      }
      /**
       * <code>string sql = 2;</code>
       * @param value The bytes for sql to set.
       * @return This builder for chaining.
       */
      public Builder setSqlBytes(
          com.google.protobuf.ByteString value) {
        if (value == null) {
    throw new NullPointerException();
  }
  checkByteStringIsUtf8(value);
        
        sql_ = value;
        onChanged();
        return this;
      }

      private java.util.List<org.apache.calcite.avatica.proto.Common.AvaticaParameter> parameters_ =
        java.util.Collections.emptyList();
      private void ensureParametersIsMutable() {
        if (!((bitField0_ & 0x00000002) != 0)) {
          parameters_ = new java.util.ArrayList<org.apache.calcite.avatica.proto.Common.AvaticaParameter>(parameters_);
          bitField0_ |= 0x00000002;
         }
      }

      private com.google.protobuf.RepeatedFieldBuilderV3<
          org.apache.calcite.avatica.proto.Common.AvaticaParameter, org.apache.calcite.avatica.proto.Common.AvaticaParameter.Builder, org.apache.calcite.avatica.proto.Common.AvaticaParameterOrBuilder> parametersBuilder_;

      /**
       * <code>repeated .AvaticaParameter parameters = 3;</code>
       */
      public java.util.List<org.apache.calcite.avatica.proto.Common.AvaticaParameter> getParametersList() {
        if (parametersBuilder_ == null) {
          return java.util.Collections.unmodifiableList(parameters_);
        } else {
          return parametersBuilder_.getMessageList();
        }
      }
      /**
       * <code>repeated .AvaticaParameter parameters = 3;</code>
       */
      public int getParametersCount() {
        if (parametersBuilder_ == null) {
          return parameters_.size();
        } else {
          return parametersBuilder_.getCount();
        }
      }
      /**
       * <code>repeated .AvaticaParameter parameters = 3;</code>
       */
      public org.apache.calcite.avatica.proto.Common.AvaticaParameter getParameters(int index) {
        if (parametersBuilder_ == null) {
          return parameters_.get(index);
        } else {
          return parametersBuilder_.getMessage(index);
        }
      }
      /**
       * <code>repeated .AvaticaParameter parameters = 3;</code>
       */
      public Builder setParameters(
          int index, org.apache.calcite.avatica.proto.Common.AvaticaParameter value) {
        if (parametersBuilder_ == null) {
          if (value == null) {
            throw new NullPointerException();
          }
          ensureParametersIsMutable();
          parameters_.set(index, value);
          onChanged();
        } else {
          parametersBuilder_.setMessage(index, value);
        }
        return this;
      }
      /**
       * <code>repeated .AvaticaParameter parameters = 3;</code>
       */
      public Builder setParameters(
          int index, org.apache.calcite.avatica.proto.Common.AvaticaParameter.Builder builderForValue) {
        if (parametersBuilder_ == null) {
          ensureParametersIsMutable();
          parameters_.set(index, builderForValue.build());
          onChanged();
        } else {
          parametersBuilder_.setMessage(index, builderForValue.build());
        }
        return this;
      }
      /**
       * <code>repeated .AvaticaParameter parameters = 3;</code>
       */
      public Builder addParameters(org.apache.calcite.avatica.proto.Common.AvaticaParameter value) {
        if (parametersBuilder_ == null) {
          if (value == null) {
            throw new NullPointerException();
          }
          ensureParametersIsMutable();
          parameters_.add(value);
          onChanged();
        } else {
          parametersBuilder_.addMessage(value);
        }
        return this;
      }
      /**
       * <code>repeated .AvaticaParameter parameters = 3;</code>
       */
      public Builder addParameters(
          int index, org.apache.calcite.avatica.proto.Common.AvaticaParameter value) {
        if (parametersBuilder_ == null) {
          if (value == null) {
            throw new NullPointerException();
          }
          ensureParametersIsMutable();
          parameters_.add(index, value);
          onChanged();
        } else {
          parametersBuilder_.addMessage(index, value);
        }
        return this;
      }
      /**
       * <code>repeated .AvaticaParameter parameters = 3;</code>
       */
      public Builder addParameters(
          org.apache.calcite.avatica.proto.Common.AvaticaParameter.Builder builderForValue) {
        if (parametersBuilder_ == null) {
          ensureParametersIsMutable();
          parameters_.add(builderForValue.build());
          onChanged();
        } else {
          parametersBuilder_.addMessage(builderForValue.build());
        }
        return this;
      }
      /**
       * <code>repeated .AvaticaParameter parameters = 3;</code>
       */
      public Builder addParameters(
          int index, org.apache.calcite.avatica.proto.Common.AvaticaParameter.Builder builderForValue) {
        if (parametersBuilder_ == null) {
          ensureParametersIsMutable();
          parameters_.add(index, builderForValue.build());
          onChanged();
        } else {
          parametersBuilder_.addMessage(index, builderForValue.build());
        }
        return this;
      }
      /**
       * <code>repeated .AvaticaParameter parameters = 3;</code>
       */
      public Builder addAllParameters(
          java.lang.Iterable<? extends org.apache.calcite.avatica.proto.Common.AvaticaParameter> values) {
        if (parametersBuilder_ == null) {
          ensureParametersIsMutable();
          com.google.protobuf.AbstractMessageLite.Builder.addAll(
              values, parameters_);
          onChanged();
        } else {
          parametersBuilder_.addAllMessages(values);
        }
        return this;
      }
      /**
       * <code>repeated .AvaticaParameter parameters = 3;</code>
       */
      public Builder clearParameters() {
        if (parametersBuilder_ == null) {
          parameters_ = java.util.Collections.emptyList();
          bitField0_ = (bitField0_ & ~0x00000002);
          onChanged();
        } else {
          parametersBuilder_.clear();
        }
        return this;
      }
      /**
       * <code>repeated .AvaticaParameter parameters = 3;</code>
       */
      public Builder removeParameters(int index) {
        if (parametersBuilder_ == null) {
          ensureParametersIsMutable();
          parameters_.remove(index);
          onChanged();
        } else {
          parametersBuilder_.remove(index);
        }
        return this;
      }
      /**
       * <code>repeated .AvaticaParameter parameters = 3;</code>
       */
      public org.apache.calcite.avatica.proto.Common.AvaticaParameter.Builder getParametersBuilder(
          int index) {
        return getParametersFieldBuilder().getBuilder(index);
      }
      /**
       * <code>repeated .AvaticaParameter parameters = 3;</code>
       */
      public org.apache.calcite.avatica.proto.Common.AvaticaParameterOrBuilder getParametersOrBuilder(
          int index) {
        if (parametersBuilder_ == null) {
          return parameters_.get(index);  } else {
          return parametersBuilder_.getMessageOrBuilder(index);
        }
      }
      /**
       * <code>repeated .AvaticaParameter parameters = 3;</code>
       */
      public java.util.List<? extends org.apache.calcite.avatica.proto.Common.AvaticaParameterOrBuilder> 
           getParametersOrBuilderList() {
        if (parametersBuilder_ != null) {
          return parametersBuilder_.getMessageOrBuilderList();
        } else {
          return java.util.Collections.unmodifiableList(parameters_);
        }
      }
      /**
       * <code>repeated .AvaticaParameter parameters = 3;</code>
       */
      public org.apache.calcite.avatica.proto.Common.AvaticaParameter.Builder addParametersBuilder() {
        return getParametersFieldBuilder().addBuilder(
            org.apache.calcite.avatica.proto.Common.AvaticaParameter.getDefaultInstance());
      }
      /**
       * <code>repeated .AvaticaParameter parameters = 3;</code>
       */
      public org.apache.calcite.avatica.proto.Common.AvaticaParameter.Builder addParametersBuilder(
          int index) {
        return getParametersFieldBuilder().addBuilder(
            index, org.apache.calcite.avatica.proto.Common.AvaticaParameter.getDefaultInstance());
      }
      /**
       * <code>repeated .AvaticaParameter parameters = 3;</code>
       */
      public java.util.List<org.apache.calcite.avatica.proto.Common.AvaticaParameter.Builder> 
           getParametersBuilderList() {
        return getParametersFieldBuilder().getBuilderList();
      }
      private com.google.protobuf.RepeatedFieldBuilderV3<
          org.apache.calcite.avatica.proto.Common.AvaticaParameter, org.apache.calcite.avatica.proto.Common.AvaticaParameter.Builder, org.apache.calcite.avatica.proto.Common.AvaticaParameterOrBuilder> 
          getParametersFieldBuilder() {
        if (parametersBuilder_ == null) {
          parametersBuilder_ = new com.google.protobuf.RepeatedFieldBuilderV3<
              org.apache.calcite.avatica.proto.Common.AvaticaParameter, org.apache.calcite.avatica.proto.Common.AvaticaParameter.Builder, org.apache.calcite.avatica.proto.Common.AvaticaParameterOrBuilder>(
                  parameters_,
                  ((bitField0_ & 0x00000002) != 0),
                  getParentForChildren(),
                  isClean());
          parameters_ = null;
        }
        return parametersBuilder_;
      }

      private org.apache.calcite.avatica.proto.Common.CursorFactory cursorFactory_;
      private com.google.protobuf.SingleFieldBuilderV3<
          org.apache.calcite.avatica.proto.Common.CursorFactory, org.apache.calcite.avatica.proto.Common.CursorFactory.Builder, org.apache.calcite.avatica.proto.Common.CursorFactoryOrBuilder> cursorFactoryBuilder_;
      /**
       * <code>.CursorFactory cursor_factory = 4;</code>
       * @return Whether the cursorFactory field is set.
       */
      public boolean hasCursorFactory() {
        return cursorFactoryBuilder_ != null || cursorFactory_ != null;
      }
      /**
       * <code>.CursorFactory cursor_factory = 4;</code>
       * @return The cursorFactory.
       */
      public org.apache.calcite.avatica.proto.Common.CursorFactory getCursorFactory() {
        if (cursorFactoryBuilder_ == null) {
          return cursorFactory_ == null ? org.apache.calcite.avatica.proto.Common.CursorFactory.getDefaultInstance() : cursorFactory_;
        } else {
          return cursorFactoryBuilder_.getMessage();
        }
      }
      /**
       * <code>.CursorFactory cursor_factory = 4;</code>
       */
      public Builder setCursorFactory(org.apache.calcite.avatica.proto.Common.CursorFactory value) {
        if (cursorFactoryBuilder_ == null) {
          if (value == null) {
            throw new NullPointerException();
          }
          cursorFactory_ = value;
          onChanged();
        } else {
          cursorFactoryBuilder_.setMessage(value);
        }

        return this;
      }
      /**
       * <code>.CursorFactory cursor_factory = 4;</code>
       */
      public Builder setCursorFactory(
          org.apache.calcite.avatica.proto.Common.CursorFactory.Builder builderForValue) {
        if (cursorFactoryBuilder_ == null) {
          cursorFactory_ = builderForValue.build();
          onChanged();
        } else {
          cursorFactoryBuilder_.setMessage(builderForValue.build());
        }

        return this;
      }
      /**
       * <code>.CursorFactory cursor_factory = 4;</code>
       */
      public Builder mergeCursorFactory(org.apache.calcite.avatica.proto.Common.CursorFactory value) {
        if (cursorFactoryBuilder_ == null) {
          if (cursorFactory_ != null) {
            cursorFactory_ =
              org.apache.calcite.avatica.proto.Common.CursorFactory.newBuilder(cursorFactory_).mergeFrom(value).buildPartial();
          } else {
            cursorFactory_ = value;
          }
          onChanged();
        } else {
          cursorFactoryBuilder_.mergeFrom(value);
        }

        return this;
      }
      /**
       * <code>.CursorFactory cursor_factory = 4;</code>
       */
      public Builder clearCursorFactory() {
        if (cursorFactoryBuilder_ == null) {
          cursorFactory_ = null;
          onChanged();
        } else {
          cursorFactory_ = null;
          cursorFactoryBuilder_ = null;
        }

        return this;
      }
      /**
       * <code>.CursorFactory cursor_factory = 4;</code>
       */
      public org.apache.calcite.avatica.proto.Common.CursorFactory.Builder getCursorFactoryBuilder() {
        
        onChanged();
        return getCursorFactoryFieldBuilder().getBuilder();
      }
      /**
       * <code>.CursorFactory cursor_factory = 4;</code>
       */
      public org.apache.calcite.avatica.proto.Common.CursorFactoryOrBuilder getCursorFactoryOrBuilder() {
        if (cursorFactoryBuilder_ != null) {
          return cursorFactoryBuilder_.getMessageOrBuilder();
        } else {
          return cursorFactory_ == null ?
              org.apache.calcite.avatica.proto.Common.CursorFactory.getDefaultInstance() : cursorFactory_;
        }
      }
      /**
       * <code>.CursorFactory cursor_factory = 4;</code>
       */
      private com.google.protobuf.SingleFieldBuilderV3<
          org.apache.calcite.avatica.proto.Common.CursorFactory, org.apache.calcite.avatica.proto.Common.CursorFactory.Builder, org.apache.calcite.avatica.proto.Common.CursorFactoryOrBuilder> 
          getCursorFactoryFieldBuilder() {
        if (cursorFactoryBuilder_ == null) {
          cursorFactoryBuilder_ = new com.google.protobuf.SingleFieldBuilderV3<
              org.apache.calcite.avatica.proto.Common.CursorFactory, org.apache.calcite.avatica.proto.Common.CursorFactory.Builder, org.apache.calcite.avatica.proto.Common.CursorFactoryOrBuilder>(
                  getCursorFactory(),
                  getParentForChildren(),
                  isClean());
          cursorFactory_ = null;
        }
        return cursorFactoryBuilder_;
      }

      private int statementType_ = 0;
      /**
       * <code>.StatementType statementType = 5;</code>
       * @return The enum numeric value on the wire for statementType.
       */
      @java.lang.Override public int getStatementTypeValue() {
        return statementType_;
      }
      /**
       * <code>.StatementType statementType = 5;</code>
       * @param value The enum numeric value on the wire for statementType to set.
       * @return This builder for chaining.
       */
      public Builder setStatementTypeValue(int value) {
        
        statementType_ = value;
        onChanged();
        return this;
      }
      /**
       * <code>.StatementType statementType = 5;</code>
       * @return The statementType.
       */
      @java.lang.Override
      public org.apache.calcite.avatica.proto.Common.StatementType getStatementType() {
        @SuppressWarnings("deprecation")
        org.apache.calcite.avatica.proto.Common.StatementType result = org.apache.calcite.avatica.proto.Common.StatementType.valueOf(statementType_);
        return result == null ? org.apache.calcite.avatica.proto.Common.StatementType.UNRECOGNIZED : result;
      }
      /**
       * <code>.StatementType statementType = 5;</code>
       * @param value The statementType to set.
       * @return This builder for chaining.
       */
      public Builder setStatementType(org.apache.calcite.avatica.proto.Common.StatementType value) {
        if (value == null) {
          throw new NullPointerException();
        }
        
        statementType_ = value.getNumber();
        onChanged();
        return this;
      }
      /**
       * <code>.StatementType statementType = 5;</code>
       * @return This builder for chaining.
       */
      public Builder clearStatementType() {
        
        statementType_ = 0;
        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:Signature)
    }

    // @@protoc_insertion_point(class_scope:Signature)
    private static final org.apache.calcite.avatica.proto.Common.Signature DEFAULT_INSTANCE;
    static {
      DEFAULT_INSTANCE = new org.apache.calcite.avatica.proto.Common.Signature();
    }

    public static org.apache.calcite.avatica.proto.Common.Signature getDefaultInstance() {
      return DEFAULT_INSTANCE;
    }

    private static final com.google.protobuf.Parser<Signature>
        PARSER = new com.google.protobuf.AbstractParser<Signature>() {
      @java.lang.Override
      public Signature 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<Signature> parser() {
      return PARSER;
    }

    @java.lang.Override
    public com.google.protobuf.Parser<Signature> getParserForType() {
      return PARSER;
    }

    @java.lang.Override
    public org.apache.calcite.avatica.proto.Common.Signature getDefaultInstanceForType() {
      return DEFAULT_INSTANCE;
    }

  }

  public interface ColumnMetaDataOrBuilder extends
      // @@protoc_insertion_point(interface_extends:ColumnMetaData)
      com.google.protobuf.MessageOrBuilder {

    /**
     * <code>uint32 ordinal = 1;</code>
     * @return The ordinal.
     */
    int getOrdinal();

    /**
     * <code>bool auto_increment = 2;</code>
     * @return The autoIncrement.
     */
    boolean getAutoIncrement();

    /**
     * <code>bool case_sensitive = 3;</code>
     * @return The caseSensitive.
     */
    boolean getCaseSensitive();

    /**
     * <code>bool searchable = 4;</code>
     * @return The searchable.
     */
    boolean getSearchable();

    /**
     * <code>bool currency = 5;</code>
     * @return The currency.
     */
    boolean getCurrency();

    /**
     * <code>uint32 nullable = 6;</code>
     * @return The nullable.
     */
    int getNullable();

    /**
     * <code>bool signed = 7;</code>
     * @return The signed.
     */
    boolean getSigned();

    /**
     * <code>uint32 display_size = 8;</code>
     * @return The displaySize.
     */
    int getDisplaySize();

    /**
     * <code>string label = 9;</code>
     * @return The label.
     */
    java.lang.String getLabel();
    /**
     * <code>string label = 9;</code>
     * @return The bytes for label.
     */
    com.google.protobuf.ByteString
        getLabelBytes();

    /**
     * <code>string column_name = 10;</code>
     * @return The columnName.
     */
    java.lang.String getColumnName();
    /**
     * <code>string column_name = 10;</code>
     * @return The bytes for columnName.
     */
    com.google.protobuf.ByteString
        getColumnNameBytes();

    /**
     * <code>string schema_name = 11;</code>
     * @return The schemaName.
     */
    java.lang.String getSchemaName();
    /**
     * <code>string schema_name = 11;</code>
     * @return The bytes for schemaName.
     */
    com.google.protobuf.ByteString
        getSchemaNameBytes();

    /**
     * <code>uint32 precision = 12;</code>
     * @return The precision.
     */
    int getPrecision();

    /**
     * <code>uint32 scale = 13;</code>
     * @return The scale.
     */
    int getScale();

    /**
     * <code>string table_name = 14;</code>
     * @return The tableName.
     */
    java.lang.String getTableName();
    /**
     * <code>string table_name = 14;</code>
     * @return The bytes for tableName.
     */
    com.google.protobuf.ByteString
        getTableNameBytes();

    /**
     * <code>string catalog_name = 15;</code>
     * @return The catalogName.
     */
    java.lang.String getCatalogName();
    /**
     * <code>string catalog_name = 15;</code>
     * @return The bytes for catalogName.
     */
    com.google.protobuf.ByteString
        getCatalogNameBytes();

    /**
     * <code>bool read_only = 16;</code>
     * @return The readOnly.
     */
    boolean getReadOnly();

    /**
     * <code>bool writable = 17;</code>
     * @return The writable.
     */
    boolean getWritable();

    /**
     * <code>bool definitely_writable = 18;</code>
     * @return The definitelyWritable.
     */
    boolean getDefinitelyWritable();

    /**
     * <code>string column_class_name = 19;</code>
     * @return The columnClassName.
     */
    java.lang.String getColumnClassName();
    /**
     * <code>string column_class_name = 19;</code>
     * @return The bytes for columnClassName.
     */
    com.google.protobuf.ByteString
        getColumnClassNameBytes();

    /**
     * <code>.AvaticaType type = 20;</code>
     * @return Whether the type field is set.
     */
    boolean hasType();
    /**
     * <code>.AvaticaType type = 20;</code>
     * @return The type.
     */
    org.apache.calcite.avatica.proto.Common.AvaticaType getType();
    /**
     * <code>.AvaticaType type = 20;</code>
     */
    org.apache.calcite.avatica.proto.Common.AvaticaTypeOrBuilder getTypeOrBuilder();
  }
  /**
   * Protobuf type {@code ColumnMetaData}
   */
  public static final class ColumnMetaData extends
      com.google.protobuf.GeneratedMessageV3 implements
      // @@protoc_insertion_point(message_implements:ColumnMetaData)
      ColumnMetaDataOrBuilder {
  private static final long serialVersionUID = 0L;
    // Use ColumnMetaData.newBuilder() to construct.
    private ColumnMetaData(com.google.protobuf.GeneratedMessageV3.Builder<?> builder) {
      super(builder);
    }
    private ColumnMetaData() {
      label_ = "";
      columnName_ = "";
      schemaName_ = "";
      tableName_ = "";
      catalogName_ = "";
      columnClassName_ = "";
    }

    @java.lang.Override
    @SuppressWarnings({"unused"})
    protected java.lang.Object newInstance(
        UnusedPrivateParameter unused) {
      return new ColumnMetaData();
    }

    @java.lang.Override
    public final com.google.protobuf.UnknownFieldSet
    getUnknownFields() {
      return this.unknownFields;
    }
    public static final com.google.protobuf.Descriptors.Descriptor
        getDescriptor() {
      return org.apache.calcite.avatica.proto.Common.internal_static_ColumnMetaData_descriptor;
    }

    @java.lang.Override
    protected com.google.protobuf.GeneratedMessageV3.FieldAccessorTable
        internalGetFieldAccessorTable() {
      return org.apache.calcite.avatica.proto.Common.internal_static_ColumnMetaData_fieldAccessorTable
          .ensureFieldAccessorsInitialized(
              org.apache.calcite.avatica.proto.Common.ColumnMetaData.class, org.apache.calcite.avatica.proto.Common.ColumnMetaData.Builder.class);
    }

    public static final int ORDINAL_FIELD_NUMBER = 1;
    private int ordinal_;
    /**
     * <code>uint32 ordinal = 1;</code>
     * @return The ordinal.
     */
    @java.lang.Override
    public int getOrdinal() {
      return ordinal_;
    }

    public static final int AUTO_INCREMENT_FIELD_NUMBER = 2;
    private boolean autoIncrement_;
    /**
     * <code>bool auto_increment = 2;</code>
     * @return The autoIncrement.
     */
    @java.lang.Override
    public boolean getAutoIncrement() {
      return autoIncrement_;
    }

    public static final int CASE_SENSITIVE_FIELD_NUMBER = 3;
    private boolean caseSensitive_;
    /**
     * <code>bool case_sensitive = 3;</code>
     * @return The caseSensitive.
     */
    @java.lang.Override
    public boolean getCaseSensitive() {
      return caseSensitive_;
    }

    public static final int SEARCHABLE_FIELD_NUMBER = 4;
    private boolean searchable_;
    /**
     * <code>bool searchable = 4;</code>
     * @return The searchable.
     */
    @java.lang.Override
    public boolean getSearchable() {
      return searchable_;
    }

    public static final int CURRENCY_FIELD_NUMBER = 5;
    private boolean currency_;
    /**
     * <code>bool currency = 5;</code>
     * @return The currency.
     */
    @java.lang.Override
    public boolean getCurrency() {
      return currency_;
    }

    public static final int NULLABLE_FIELD_NUMBER = 6;
    private int nullable_;
    /**
     * <code>uint32 nullable = 6;</code>
     * @return The nullable.
     */
    @java.lang.Override
    public int getNullable() {
      return nullable_;
    }

    public static final int SIGNED_FIELD_NUMBER = 7;
    private boolean signed_;
    /**
     * <code>bool signed = 7;</code>
     * @return The signed.
     */
    @java.lang.Override
    public boolean getSigned() {
      return signed_;
    }

    public static final int DISPLAY_SIZE_FIELD_NUMBER = 8;
    private int displaySize_;
    /**
     * <code>uint32 display_size = 8;</code>
     * @return The displaySize.
     */
    @java.lang.Override
    public int getDisplaySize() {
      return displaySize_;
    }

    public static final int LABEL_FIELD_NUMBER = 9;
    private volatile java.lang.Object label_;
    /**
     * <code>string label = 9;</code>
     * @return The label.
     */
    @java.lang.Override
    public java.lang.String getLabel() {
      java.lang.Object ref = label_;
      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();
        label_ = s;
        return s;
      }
    }
    /**
     * <code>string label = 9;</code>
     * @return The bytes for label.
     */
    @java.lang.Override
    public com.google.protobuf.ByteString
        getLabelBytes() {
      java.lang.Object ref = label_;
      if (ref instanceof java.lang.String) {
        com.google.protobuf.ByteString b = 
            com.google.protobuf.ByteString.copyFromUtf8(
                (java.lang.String) ref);
        label_ = b;
        return b;
      } else {
        return (com.google.protobuf.ByteString) ref;
      }
    }

    public static final int COLUMN_NAME_FIELD_NUMBER = 10;
    private volatile java.lang.Object columnName_;
    /**
     * <code>string column_name = 10;</code>
     * @return The columnName.
     */
    @java.lang.Override
    public java.lang.String getColumnName() {
      java.lang.Object ref = columnName_;
      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();
        columnName_ = s;
        return s;
      }
    }
    /**
     * <code>string column_name = 10;</code>
     * @return The bytes for columnName.
     */
    @java.lang.Override
    public com.google.protobuf.ByteString
        getColumnNameBytes() {
      java.lang.Object ref = columnName_;
      if (ref instanceof java.lang.String) {
        com.google.protobuf.ByteString b = 
            com.google.protobuf.ByteString.copyFromUtf8(
                (java.lang.String) ref);
        columnName_ = b;
        return b;
      } else {
        return (com.google.protobuf.ByteString) ref;
      }
    }

    public static final int SCHEMA_NAME_FIELD_NUMBER = 11;
    private volatile java.lang.Object schemaName_;
    /**
     * <code>string schema_name = 11;</code>
     * @return The schemaName.
     */
    @java.lang.Override
    public java.lang.String getSchemaName() {
      java.lang.Object ref = schemaName_;
      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();
        schemaName_ = s;
        return s;
      }
    }
    /**
     * <code>string schema_name = 11;</code>
     * @return The bytes for schemaName.
     */
    @java.lang.Override
    public com.google.protobuf.ByteString
        getSchemaNameBytes() {
      java.lang.Object ref = schemaName_;
      if (ref instanceof java.lang.String) {
        com.google.protobuf.ByteString b = 
            com.google.protobuf.ByteString.copyFromUtf8(
                (java.lang.String) ref);
        schemaName_ = b;
        return b;
      } else {
        return (com.google.protobuf.ByteString) ref;
      }
    }

    public static final int PRECISION_FIELD_NUMBER = 12;
    private int precision_;
    /**
     * <code>uint32 precision = 12;</code>
     * @return The precision.
     */
    @java.lang.Override
    public int getPrecision() {
      return precision_;
    }

    public static final int SCALE_FIELD_NUMBER = 13;
    private int scale_;
    /**
     * <code>uint32 scale = 13;</code>
     * @return The scale.
     */
    @java.lang.Override
    public int getScale() {
      return scale_;
    }

    public static final int TABLE_NAME_FIELD_NUMBER = 14;
    private volatile java.lang.Object tableName_;
    /**
     * <code>string table_name = 14;</code>
     * @return The tableName.
     */
    @java.lang.Override
    public java.lang.String getTableName() {
      java.lang.Object ref = tableName_;
      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();
        tableName_ = s;
        return s;
      }
    }
    /**
     * <code>string table_name = 14;</code>
     * @return The bytes for tableName.
     */
    @java.lang.Override
    public com.google.protobuf.ByteString
        getTableNameBytes() {
      java.lang.Object ref = tableName_;
      if (ref instanceof java.lang.String) {
        com.google.protobuf.ByteString b = 
            com.google.protobuf.ByteString.copyFromUtf8(
                (java.lang.String) ref);
        tableName_ = b;
        return b;
      } else {
        return (com.google.protobuf.ByteString) ref;
      }
    }

    public static final int CATALOG_NAME_FIELD_NUMBER = 15;
    private volatile java.lang.Object catalogName_;
    /**
     * <code>string catalog_name = 15;</code>
     * @return The catalogName.
     */
    @java.lang.Override
    public java.lang.String getCatalogName() {
      java.lang.Object ref = catalogName_;
      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();
        catalogName_ = s;
        return s;
      }
    }
    /**
     * <code>string catalog_name = 15;</code>
     * @return The bytes for catalogName.
     */
    @java.lang.Override
    public com.google.protobuf.ByteString
        getCatalogNameBytes() {
      java.lang.Object ref = catalogName_;
      if (ref instanceof java.lang.String) {
        com.google.protobuf.ByteString b = 
            com.google.protobuf.ByteString.copyFromUtf8(
                (java.lang.String) ref);
        catalogName_ = b;
        return b;
      } else {
        return (com.google.protobuf.ByteString) ref;
      }
    }

    public static final int READ_ONLY_FIELD_NUMBER = 16;
    private boolean readOnly_;
    /**
     * <code>bool read_only = 16;</code>
     * @return The readOnly.
     */
    @java.lang.Override
    public boolean getReadOnly() {
      return readOnly_;
    }

    public static final int WRITABLE_FIELD_NUMBER = 17;
    private boolean writable_;
    /**
     * <code>bool writable = 17;</code>
     * @return The writable.
     */
    @java.lang.Override
    public boolean getWritable() {
      return writable_;
    }

    public static final int DEFINITELY_WRITABLE_FIELD_NUMBER = 18;
    private boolean definitelyWritable_;
    /**
     * <code>bool definitely_writable = 18;</code>
     * @return The definitelyWritable.
     */
    @java.lang.Override
    public boolean getDefinitelyWritable() {
      return definitelyWritable_;
    }

    public static final int COLUMN_CLASS_NAME_FIELD_NUMBER = 19;
    private volatile java.lang.Object columnClassName_;
    /**
     * <code>string column_class_name = 19;</code>
     * @return The columnClassName.
     */
    @java.lang.Override
    public java.lang.String getColumnClassName() {
      java.lang.Object ref = columnClassName_;
      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();
        columnClassName_ = s;
        return s;
      }
    }
    /**
     * <code>string column_class_name = 19;</code>
     * @return The bytes for columnClassName.
     */
    @java.lang.Override
    public com.google.protobuf.ByteString
        getColumnClassNameBytes() {
      java.lang.Object ref = columnClassName_;
      if (ref instanceof java.lang.String) {
        com.google.protobuf.ByteString b = 
            com.google.protobuf.ByteString.copyFromUtf8(
                (java.lang.String) ref);
        columnClassName_ = b;
        return b;
      } else {
        return (com.google.protobuf.ByteString) ref;
      }
    }

    public static final int TYPE_FIELD_NUMBER = 20;
    private org.apache.calcite.avatica.proto.Common.AvaticaType type_;
    /**
     * <code>.AvaticaType type = 20;</code>
     * @return Whether the type field is set.
     */
    @java.lang.Override
    public boolean hasType() {
      return type_ != null;
    }
    /**
     * <code>.AvaticaType type = 20;</code>
     * @return The type.
     */
    @java.lang.Override
    public org.apache.calcite.avatica.proto.Common.AvaticaType getType() {
      return type_ == null ? org.apache.calcite.avatica.proto.Common.AvaticaType.getDefaultInstance() : type_;
    }
    /**
     * <code>.AvaticaType type = 20;</code>
     */
    @java.lang.Override
    public org.apache.calcite.avatica.proto.Common.AvaticaTypeOrBuilder getTypeOrBuilder() {
      return getType();
    }

    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 (ordinal_ != 0) {
        output.writeUInt32(1, ordinal_);
      }
      if (autoIncrement_ != false) {
        output.writeBool(2, autoIncrement_);
      }
      if (caseSensitive_ != false) {
        output.writeBool(3, caseSensitive_);
      }
      if (searchable_ != false) {
        output.writeBool(4, searchable_);
      }
      if (currency_ != false) {
        output.writeBool(5, currency_);
      }
      if (nullable_ != 0) {
        output.writeUInt32(6, nullable_);
      }
      if (signed_ != false) {
        output.writeBool(7, signed_);
      }
      if (displaySize_ != 0) {
        output.writeUInt32(8, displaySize_);
      }
      if (!com.google.protobuf.GeneratedMessageV3.isStringEmpty(label_)) {
        com.google.protobuf.GeneratedMessageV3.writeString(output, 9, label_);
      }
      if (!com.google.protobuf.GeneratedMessageV3.isStringEmpty(columnName_)) {
        com.google.protobuf.GeneratedMessageV3.writeString(output, 10, columnName_);
      }
      if (!com.google.protobuf.GeneratedMessageV3.isStringEmpty(schemaName_)) {
        com.google.protobuf.GeneratedMessageV3.writeString(output, 11, schemaName_);
      }
      if (precision_ != 0) {
        output.writeUInt32(12, precision_);
      }
      if (scale_ != 0) {
        output.writeUInt32(13, scale_);
      }
      if (!com.google.protobuf.GeneratedMessageV3.isStringEmpty(tableName_)) {
        com.google.protobuf.GeneratedMessageV3.writeString(output, 14, tableName_);
      }
      if (!com.google.protobuf.GeneratedMessageV3.isStringEmpty(catalogName_)) {
        com.google.protobuf.GeneratedMessageV3.writeString(output, 15, catalogName_);
      }
      if (readOnly_ != false) {
        output.writeBool(16, readOnly_);
      }
      if (writable_ != false) {
        output.writeBool(17, writable_);
      }
      if (definitelyWritable_ != false) {
        output.writeBool(18, definitelyWritable_);
      }
      if (!com.google.protobuf.GeneratedMessageV3.isStringEmpty(columnClassName_)) {
        com.google.protobuf.GeneratedMessageV3.writeString(output, 19, columnClassName_);
      }
      if (type_ != null) {
        output.writeMessage(20, getType());
      }
      getUnknownFields().writeTo(output);
    }

    @java.lang.Override
    public int getSerializedSize() {
      int size = memoizedSize;
      if (size != -1) return size;

      size = 0;
      if (ordinal_ != 0) {
        size += com.google.protobuf.CodedOutputStream
          .computeUInt32Size(1, ordinal_);
      }
      if (autoIncrement_ != false) {
        size += com.google.protobuf.CodedOutputStream
          .computeBoolSize(2, autoIncrement_);
      }
      if (caseSensitive_ != false) {
        size += com.google.protobuf.CodedOutputStream
          .computeBoolSize(3, caseSensitive_);
      }
      if (searchable_ != false) {
        size += com.google.protobuf.CodedOutputStream
          .computeBoolSize(4, searchable_);
      }
      if (currency_ != false) {
        size += com.google.protobuf.CodedOutputStream
          .computeBoolSize(5, currency_);
      }
      if (nullable_ != 0) {
        size += com.google.protobuf.CodedOutputStream
          .computeUInt32Size(6, nullable_);
      }
      if (signed_ != false) {
        size += com.google.protobuf.CodedOutputStream
          .computeBoolSize(7, signed_);
      }
      if (displaySize_ != 0) {
        size += com.google.protobuf.CodedOutputStream
          .computeUInt32Size(8, displaySize_);
      }
      if (!com.google.protobuf.GeneratedMessageV3.isStringEmpty(label_)) {
        size += com.google.protobuf.GeneratedMessageV3.computeStringSize(9, label_);
      }
      if (!com.google.protobuf.GeneratedMessageV3.isStringEmpty(columnName_)) {
        size += com.google.protobuf.GeneratedMessageV3.computeStringSize(10, columnName_);
      }
      if (!com.google.protobuf.GeneratedMessageV3.isStringEmpty(schemaName_)) {
        size += com.google.protobuf.GeneratedMessageV3.computeStringSize(11, schemaName_);
      }
      if (precision_ != 0) {
        size += com.google.protobuf.CodedOutputStream
          .computeUInt32Size(12, precision_);
      }
      if (scale_ != 0) {
        size += com.google.protobuf.CodedOutputStream
          .computeUInt32Size(13, scale_);
      }
      if (!com.google.protobuf.GeneratedMessageV3.isStringEmpty(tableName_)) {
        size += com.google.protobuf.GeneratedMessageV3.computeStringSize(14, tableName_);
      }
      if (!com.google.protobuf.GeneratedMessageV3.isStringEmpty(catalogName_)) {
        size += com.google.protobuf.GeneratedMessageV3.computeStringSize(15, catalogName_);
      }
      if (readOnly_ != false) {
        size += com.google.protobuf.CodedOutputStream
          .computeBoolSize(16, readOnly_);
      }
      if (writable_ != false) {
        size += com.google.protobuf.CodedOutputStream
          .computeBoolSize(17, writable_);
      }
      if (definitelyWritable_ != false) {
        size += com.google.protobuf.CodedOutputStream
          .computeBoolSize(18, definitelyWritable_);
      }
      if (!com.google.protobuf.GeneratedMessageV3.isStringEmpty(columnClassName_)) {
        size += com.google.protobuf.GeneratedMessageV3.computeStringSize(19, columnClassName_);
      }
      if (type_ != null) {
        size += com.google.protobuf.CodedOutputStream
          .computeMessageSize(20, getType());
      }
      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 org.apache.calcite.avatica.proto.Common.ColumnMetaData)) {
        return super.equals(obj);
      }
      org.apache.calcite.avatica.proto.Common.ColumnMetaData other = (org.apache.calcite.avatica.proto.Common.ColumnMetaData) obj;

      if (getOrdinal()
          != other.getOrdinal()) return false;
      if (getAutoIncrement()
          != other.getAutoIncrement()) return false;
      if (getCaseSensitive()
          != other.getCaseSensitive()) return false;
      if (getSearchable()
          != other.getSearchable()) return false;
      if (getCurrency()
          != other.getCurrency()) return false;
      if (getNullable()
          != other.getNullable()) return false;
      if (getSigned()
          != other.getSigned()) return false;
      if (getDisplaySize()
          != other.getDisplaySize()) return false;
      if (!getLabel()
          .equals(other.getLabel())) return false;
      if (!getColumnName()
          .equals(other.getColumnName())) return false;
      if (!getSchemaName()
          .equals(other.getSchemaName())) return false;
      if (getPrecision()
          != other.getPrecision()) return false;
      if (getScale()
          != other.getScale()) return false;
      if (!getTableName()
          .equals(other.getTableName())) return false;
      if (!getCatalogName()
          .equals(other.getCatalogName())) return false;
      if (getReadOnly()
          != other.getReadOnly()) return false;
      if (getWritable()
          != other.getWritable()) return false;
      if (getDefinitelyWritable()
          != other.getDefinitelyWritable()) return false;
      if (!getColumnClassName()
          .equals(other.getColumnClassName())) return false;
      if (hasType() != other.hasType()) return false;
      if (hasType()) {
        if (!getType()
            .equals(other.getType())) 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();
      hash = (37 * hash) + ORDINAL_FIELD_NUMBER;
      hash = (53 * hash) + getOrdinal();
      hash = (37 * hash) + AUTO_INCREMENT_FIELD_NUMBER;
      hash = (53 * hash) + com.google.protobuf.Internal.hashBoolean(
          getAutoIncrement());
      hash = (37 * hash) + CASE_SENSITIVE_FIELD_NUMBER;
      hash = (53 * hash) + com.google.protobuf.Internal.hashBoolean(
          getCaseSensitive());
      hash = (37 * hash) + SEARCHABLE_FIELD_NUMBER;
      hash = (53 * hash) + com.google.protobuf.Internal.hashBoolean(
          getSearchable());
      hash = (37 * hash) + CURRENCY_FIELD_NUMBER;
      hash = (53 * hash) + com.google.protobuf.Internal.hashBoolean(
          getCurrency());
      hash = (37 * hash) + NULLABLE_FIELD_NUMBER;
      hash = (53 * hash) + getNullable();
      hash = (37 * hash) + SIGNED_FIELD_NUMBER;
      hash = (53 * hash) + com.google.protobuf.Internal.hashBoolean(
          getSigned());
      hash = (37 * hash) + DISPLAY_SIZE_FIELD_NUMBER;
      hash = (53 * hash) + getDisplaySize();
      hash = (37 * hash) + LABEL_FIELD_NUMBER;
      hash = (53 * hash) + getLabel().hashCode();
      hash = (37 * hash) + COLUMN_NAME_FIELD_NUMBER;
      hash = (53 * hash) + getColumnName().hashCode();
      hash = (37 * hash) + SCHEMA_NAME_FIELD_NUMBER;
      hash = (53 * hash) + getSchemaName().hashCode();
      hash = (37 * hash) + PRECISION_FIELD_NUMBER;
      hash = (53 * hash) + getPrecision();
      hash = (37 * hash) + SCALE_FIELD_NUMBER;
      hash = (53 * hash) + getScale();
      hash = (37 * hash) + TABLE_NAME_FIELD_NUMBER;
      hash = (53 * hash) + getTableName().hashCode();
      hash = (37 * hash) + CATALOG_NAME_FIELD_NUMBER;
      hash = (53 * hash) + getCatalogName().hashCode();
      hash = (37 * hash) + READ_ONLY_FIELD_NUMBER;
      hash = (53 * hash) + com.google.protobuf.Internal.hashBoolean(
          getReadOnly());
      hash = (37 * hash) + WRITABLE_FIELD_NUMBER;
      hash = (53 * hash) + com.google.protobuf.Internal.hashBoolean(
          getWritable());
      hash = (37 * hash) + DEFINITELY_WRITABLE_FIELD_NUMBER;
      hash = (53 * hash) + com.google.protobuf.Internal.hashBoolean(
          getDefinitelyWritable());
      hash = (37 * hash) + COLUMN_CLASS_NAME_FIELD_NUMBER;
      hash = (53 * hash) + getColumnClassName().hashCode();
      if (hasType()) {
        hash = (37 * hash) + TYPE_FIELD_NUMBER;
        hash = (53 * hash) + getType().hashCode();
      }
      hash = (29 * hash) + getUnknownFields().hashCode();
      memoizedHashCode = hash;
      return hash;
    }

    public static org.apache.calcite.avatica.proto.Common.ColumnMetaData parseFrom(
        java.nio.ByteBuffer data)
        throws com.google.protobuf.InvalidProtocolBufferException {
      return PARSER.parseFrom(data);
    }
    public static org.apache.calcite.avatica.proto.Common.ColumnMetaData parseFrom(
        java.nio.ByteBuffer data,
        com.google.protobuf.ExtensionRegistryLite extensionRegistry)
        throws com.google.protobuf.InvalidProtocolBufferException {
      return PARSER.parseFrom(data, extensionRegistry);
    }
    public static org.apache.calcite.avatica.proto.Common.ColumnMetaData parseFrom(
        com.google.protobuf.ByteString data)
        throws com.google.protobuf.InvalidProtocolBufferException {
      return PARSER.parseFrom(data);
    }
    public static org.apache.calcite.avatica.proto.Common.ColumnMetaData parseFrom(
        com.google.protobuf.ByteString data,
        com.google.protobuf.ExtensionRegistryLite extensionRegistry)
        throws com.google.protobuf.InvalidProtocolBufferException {
      return PARSER.parseFrom(data, extensionRegistry);
    }
    public static org.apache.calcite.avatica.proto.Common.ColumnMetaData parseFrom(byte[] data)
        throws com.google.protobuf.InvalidProtocolBufferException {
      return PARSER.parseFrom(data);
    }
    public static org.apache.calcite.avatica.proto.Common.ColumnMetaData parseFrom(
        byte[] data,
        com.google.protobuf.ExtensionRegistryLite extensionRegistry)
        throws com.google.protobuf.InvalidProtocolBufferException {
      return PARSER.parseFrom(data, extensionRegistry);
    }
    public static org.apache.calcite.avatica.proto.Common.ColumnMetaData parseFrom(java.io.InputStream input)
        throws java.io.IOException {
      return com.google.protobuf.GeneratedMessageV3
          .parseWithIOException(PARSER, input);
    }
    public static org.apache.calcite.avatica.proto.Common.ColumnMetaData 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 org.apache.calcite.avatica.proto.Common.ColumnMetaData parseDelimitedFrom(java.io.InputStream input)
        throws java.io.IOException {
      return com.google.protobuf.GeneratedMessageV3
          .parseDelimitedWithIOException(PARSER, input);
    }
    public static org.apache.calcite.avatica.proto.Common.ColumnMetaData 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 org.apache.calcite.avatica.proto.Common.ColumnMetaData parseFrom(
        com.google.protobuf.CodedInputStream input)
        throws java.io.IOException {
      return com.google.protobuf.GeneratedMessageV3
          .parseWithIOException(PARSER, input);
    }
    public static org.apache.calcite.avatica.proto.Common.ColumnMetaData 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(org.apache.calcite.avatica.proto.Common.ColumnMetaData 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;
    }
    /**
     * Protobuf type {@code ColumnMetaData}
     */
    public static final class Builder extends
        com.google.protobuf.GeneratedMessageV3.Builder<Builder> implements
        // @@protoc_insertion_point(builder_implements:ColumnMetaData)
        org.apache.calcite.avatica.proto.Common.ColumnMetaDataOrBuilder {
      public static final com.google.protobuf.Descriptors.Descriptor
          getDescriptor() {
        return org.apache.calcite.avatica.proto.Common.internal_static_ColumnMetaData_descriptor;
      }

      @java.lang.Override
      protected com.google.protobuf.GeneratedMessageV3.FieldAccessorTable
          internalGetFieldAccessorTable() {
        return org.apache.calcite.avatica.proto.Common.internal_static_ColumnMetaData_fieldAccessorTable
            .ensureFieldAccessorsInitialized(
                org.apache.calcite.avatica.proto.Common.ColumnMetaData.class, org.apache.calcite.avatica.proto.Common.ColumnMetaData.Builder.class);
      }

      // Construct using org.apache.calcite.avatica.proto.Common.ColumnMetaData.newBuilder()
      private Builder() {

      }

      private Builder(
          com.google.protobuf.GeneratedMessageV3.BuilderParent parent) {
        super(parent);

      }
      @java.lang.Override
      public Builder clear() {
        super.clear();
        ordinal_ = 0;

        autoIncrement_ = false;

        caseSensitive_ = false;

        searchable_ = false;

        currency_ = false;

        nullable_ = 0;

        signed_ = false;

        displaySize_ = 0;

        label_ = "";

        columnName_ = "";

        schemaName_ = "";

        precision_ = 0;

        scale_ = 0;

        tableName_ = "";

        catalogName_ = "";

        readOnly_ = false;

        writable_ = false;

        definitelyWritable_ = false;

        columnClassName_ = "";

        if (typeBuilder_ == null) {
          type_ = null;
        } else {
          type_ = null;
          typeBuilder_ = null;
        }
        return this;
      }

      @java.lang.Override
      public com.google.protobuf.Descriptors.Descriptor
          getDescriptorForType() {
        return org.apache.calcite.avatica.proto.Common.internal_static_ColumnMetaData_descriptor;
      }

      @java.lang.Override
      public org.apache.calcite.avatica.proto.Common.ColumnMetaData getDefaultInstanceForType() {
        return org.apache.calcite.avatica.proto.Common.ColumnMetaData.getDefaultInstance();
      }

      @java.lang.Override
      public org.apache.calcite.avatica.proto.Common.ColumnMetaData build() {
        org.apache.calcite.avatica.proto.Common.ColumnMetaData result = buildPartial();
        if (!result.isInitialized()) {
          throw newUninitializedMessageException(result);
        }
        return result;
      }

      @java.lang.Override
      public org.apache.calcite.avatica.proto.Common.ColumnMetaData buildPartial() {
        org.apache.calcite.avatica.proto.Common.ColumnMetaData result = new org.apache.calcite.avatica.proto.Common.ColumnMetaData(this);
        result.ordinal_ = ordinal_;
        result.autoIncrement_ = autoIncrement_;
        result.caseSensitive_ = caseSensitive_;
        result.searchable_ = searchable_;
        result.currency_ = currency_;
        result.nullable_ = nullable_;
        result.signed_ = signed_;
        result.displaySize_ = displaySize_;
        result.label_ = label_;
        result.columnName_ = columnName_;
        result.schemaName_ = schemaName_;
        result.precision_ = precision_;
        result.scale_ = scale_;
        result.tableName_ = tableName_;
        result.catalogName_ = catalogName_;
        result.readOnly_ = readOnly_;
        result.writable_ = writable_;
        result.definitelyWritable_ = definitelyWritable_;
        result.columnClassName_ = columnClassName_;
        if (typeBuilder_ == null) {
          result.type_ = type_;
        } else {
          result.type_ = typeBuilder_.build();
        }
        onBuilt();
        return result;
      }

      @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 org.apache.calcite.avatica.proto.Common.ColumnMetaData) {
          return mergeFrom((org.apache.calcite.avatica.proto.Common.ColumnMetaData)other);
        } else {
          super.mergeFrom(other);
          return this;
        }
      }

      public Builder mergeFrom(org.apache.calcite.avatica.proto.Common.ColumnMetaData other) {
        if (other == org.apache.calcite.avatica.proto.Common.ColumnMetaData.getDefaultInstance()) return this;
        if (other.getOrdinal() != 0) {
          setOrdinal(other.getOrdinal());
        }
        if (other.getAutoIncrement() != false) {
          setAutoIncrement(other.getAutoIncrement());
        }
        if (other.getCaseSensitive() != false) {
          setCaseSensitive(other.getCaseSensitive());
        }
        if (other.getSearchable() != false) {
          setSearchable(other.getSearchable());
        }
        if (other.getCurrency() != false) {
          setCurrency(other.getCurrency());
        }
        if (other.getNullable() != 0) {
          setNullable(other.getNullable());
        }
        if (other.getSigned() != false) {
          setSigned(other.getSigned());
        }
        if (other.getDisplaySize() != 0) {
          setDisplaySize(other.getDisplaySize());
        }
        if (!other.getLabel().isEmpty()) {
          label_ = other.label_;
          onChanged();
        }
        if (!other.getColumnName().isEmpty()) {
          columnName_ = other.columnName_;
          onChanged();
        }
        if (!other.getSchemaName().isEmpty()) {
          schemaName_ = other.schemaName_;
          onChanged();
        }
        if (other.getPrecision() != 0) {
          setPrecision(other.getPrecision());
        }
        if (other.getScale() != 0) {
          setScale(other.getScale());
        }
        if (!other.getTableName().isEmpty()) {
          tableName_ = other.tableName_;
          onChanged();
        }
        if (!other.getCatalogName().isEmpty()) {
          catalogName_ = other.catalogName_;
          onChanged();
        }
        if (other.getReadOnly() != false) {
          setReadOnly(other.getReadOnly());
        }
        if (other.getWritable() != false) {
          setWritable(other.getWritable());
        }
        if (other.getDefinitelyWritable() != false) {
          setDefinitelyWritable(other.getDefinitelyWritable());
        }
        if (!other.getColumnClassName().isEmpty()) {
          columnClassName_ = other.columnClassName_;
          onChanged();
        }
        if (other.hasType()) {
          mergeType(other.getType());
        }
        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: {
                ordinal_ = input.readUInt32();

                break;
              } // case 8
              case 16: {
                autoIncrement_ = input.readBool();

                break;
              } // case 16
              case 24: {
                caseSensitive_ = input.readBool();

                break;
              } // case 24
              case 32: {
                searchable_ = input.readBool();

                break;
              } // case 32
              case 40: {
                currency_ = input.readBool();

                break;
              } // case 40
              case 48: {
                nullable_ = input.readUInt32();

                break;
              } // case 48
              case 56: {
                signed_ = input.readBool();

                break;
              } // case 56
              case 64: {
                displaySize_ = input.readUInt32();

                break;
              } // case 64
              case 74: {
                label_ = input.readStringRequireUtf8();

                break;
              } // case 74
              case 82: {
                columnName_ = input.readStringRequireUtf8();

                break;
              } // case 82
              case 90: {
                schemaName_ = input.readStringRequireUtf8();

                break;
              } // case 90
              case 96: {
                precision_ = input.readUInt32();

                break;
              } // case 96
              case 104: {
                scale_ = input.readUInt32();

                break;
              } // case 104
              case 114: {
                tableName_ = input.readStringRequireUtf8();

                break;
              } // case 114
              case 122: {
                catalogName_ = input.readStringRequireUtf8();

                break;
              } // case 122
              case 128: {
                readOnly_ = input.readBool();

                break;
              } // case 128
              case 136: {
                writable_ = input.readBool();

                break;
              } // case 136
              case 144: {
                definitelyWritable_ = input.readBool();

                break;
              } // case 144
              case 154: {
                columnClassName_ = input.readStringRequireUtf8();

                break;
              } // case 154
              case 162: {
                input.readMessage(
                    getTypeFieldBuilder().getBuilder(),
                    extensionRegistry);

                break;
              } // case 162
              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 ordinal_ ;
      /**
       * <code>uint32 ordinal = 1;</code>
       * @return The ordinal.
       */
      @java.lang.Override
      public int getOrdinal() {
        return ordinal_;
      }
      /**
       * <code>uint32 ordinal = 1;</code>
       * @param value The ordinal to set.
       * @return This builder for chaining.
       */
      public Builder setOrdinal(int value) {
        
        ordinal_ = value;
        onChanged();
        return this;
      }
      /**
       * <code>uint32 ordinal = 1;</code>
       * @return This builder for chaining.
       */
      public Builder clearOrdinal() {
        
        ordinal_ = 0;
        onChanged();
        return this;
      }

      private boolean autoIncrement_ ;
      /**
       * <code>bool auto_increment = 2;</code>
       * @return The autoIncrement.
       */
      @java.lang.Override
      public boolean getAutoIncrement() {
        return autoIncrement_;
      }
      /**
       * <code>bool auto_increment = 2;</code>
       * @param value The autoIncrement to set.
       * @return This builder for chaining.
       */
      public Builder setAutoIncrement(boolean value) {
        
        autoIncrement_ = value;
        onChanged();
        return this;
      }
      /**
       * <code>bool auto_increment = 2;</code>
       * @return This builder for chaining.
       */
      public Builder clearAutoIncrement() {
        
        autoIncrement_ = false;
        onChanged();
        return this;
      }

      private boolean caseSensitive_ ;
      /**
       * <code>bool case_sensitive = 3;</code>
       * @return The caseSensitive.
       */
      @java.lang.Override
      public boolean getCaseSensitive() {
        return caseSensitive_;
      }
      /**
       * <code>bool case_sensitive = 3;</code>
       * @param value The caseSensitive to set.
       * @return This builder for chaining.
       */
      public Builder setCaseSensitive(boolean value) {
        
        caseSensitive_ = value;
        onChanged();
        return this;
      }
      /**
       * <code>bool case_sensitive = 3;</code>
       * @return This builder for chaining.
       */
      public Builder clearCaseSensitive() {
        
        caseSensitive_ = false;
        onChanged();
        return this;
      }

      private boolean searchable_ ;
      /**
       * <code>bool searchable = 4;</code>
       * @return The searchable.
       */
      @java.lang.Override
      public boolean getSearchable() {
        return searchable_;
      }
      /**
       * <code>bool searchable = 4;</code>
       * @param value The searchable to set.
       * @return This builder for chaining.
       */
      public Builder setSearchable(boolean value) {
        
        searchable_ = value;
        onChanged();
        return this;
      }
      /**
       * <code>bool searchable = 4;</code>
       * @return This builder for chaining.
       */
      public Builder clearSearchable() {
        
        searchable_ = false;
        onChanged();
        return this;
      }

      private boolean currency_ ;
      /**
       * <code>bool currency = 5;</code>
       * @return The currency.
       */
      @java.lang.Override
      public boolean getCurrency() {
        return currency_;
      }
      /**
       * <code>bool currency = 5;</code>
       * @param value The currency to set.
       * @return This builder for chaining.
       */
      public Builder setCurrency(boolean value) {
        
        currency_ = value;
        onChanged();
        return this;
      }
      /**
       * <code>bool currency = 5;</code>
       * @return This builder for chaining.
       */
      public Builder clearCurrency() {
        
        currency_ = false;
        onChanged();
        return this;
      }

      private int nullable_ ;
      /**
       * <code>uint32 nullable = 6;</code>
       * @return The nullable.
       */
      @java.lang.Override
      public int getNullable() {
        return nullable_;
      }
      /**
       * <code>uint32 nullable = 6;</code>
       * @param value The nullable to set.
       * @return This builder for chaining.
       */
      public Builder setNullable(int value) {
        
        nullable_ = value;
        onChanged();
        return this;
      }
      /**
       * <code>uint32 nullable = 6;</code>
       * @return This builder for chaining.
       */
      public Builder clearNullable() {
        
        nullable_ = 0;
        onChanged();
        return this;
      }

      private boolean signed_ ;
      /**
       * <code>bool signed = 7;</code>
       * @return The signed.
       */
      @java.lang.Override
      public boolean getSigned() {
        return signed_;
      }
      /**
       * <code>bool signed = 7;</code>
       * @param value The signed to set.
       * @return This builder for chaining.
       */
      public Builder setSigned(boolean value) {
        
        signed_ = value;
        onChanged();
        return this;
      }
      /**
       * <code>bool signed = 7;</code>
       * @return This builder for chaining.
       */
      public Builder clearSigned() {
        
        signed_ = false;
        onChanged();
        return this;
      }

      private int displaySize_ ;
      /**
       * <code>uint32 display_size = 8;</code>
       * @return The displaySize.
       */
      @java.lang.Override
      public int getDisplaySize() {
        return displaySize_;
      }
      /**
       * <code>uint32 display_size = 8;</code>
       * @param value The displaySize to set.
       * @return This builder for chaining.
       */
      public Builder setDisplaySize(int value) {
        
        displaySize_ = value;
        onChanged();
        return this;
      }
      /**
       * <code>uint32 display_size = 8;</code>
       * @return This builder for chaining.
       */
      public Builder clearDisplaySize() {
        
        displaySize_ = 0;
        onChanged();
        return this;
      }

      private java.lang.Object label_ = "";
      /**
       * <code>string label = 9;</code>
       * @return The label.
       */
      public java.lang.String getLabel() {
        java.lang.Object ref = label_;
        if (!(ref instanceof java.lang.String)) {
          com.google.protobuf.ByteString bs =
              (com.google.protobuf.ByteString) ref;
          java.lang.String s = bs.toStringUtf8();
          label_ = s;
          return s;
        } else {
          return (java.lang.String) ref;
        }
      }
      /**
       * <code>string label = 9;</code>
       * @return The bytes for label.
       */
      public com.google.protobuf.ByteString
          getLabelBytes() {
        java.lang.Object ref = label_;
        if (ref instanceof String) {
          com.google.protobuf.ByteString b = 
              com.google.protobuf.ByteString.copyFromUtf8(
                  (java.lang.String) ref);
          label_ = b;
          return b;
        } else {
          return (com.google.protobuf.ByteString) ref;
        }
      }
      /**
       * <code>string label = 9;</code>
       * @param value The label to set.
       * @return This builder for chaining.
       */
      public Builder setLabel(
          java.lang.String value) {
        if (value == null) {
    throw new NullPointerException();
  }
  
        label_ = value;
        onChanged();
        return this;
      }
      /**
       * <code>string label = 9;</code>
       * @return This builder for chaining.
       */
      public Builder clearLabel() {
        
        label_ = getDefaultInstance().getLabel();
        onChanged();
        return this;
      }
      /**
       * <code>string label = 9;</code>
       * @param value The bytes for label to set.
       * @return This builder for chaining.
       */
      public Builder setLabelBytes(
          com.google.protobuf.ByteString value) {
        if (value == null) {
    throw new NullPointerException();
  }
  checkByteStringIsUtf8(value);
        
        label_ = value;
        onChanged();
        return this;
      }

      private java.lang.Object columnName_ = "";
      /**
       * <code>string column_name = 10;</code>
       * @return The columnName.
       */
      public java.lang.String getColumnName() {
        java.lang.Object ref = columnName_;
        if (!(ref instanceof java.lang.String)) {
          com.google.protobuf.ByteString bs =
              (com.google.protobuf.ByteString) ref;
          java.lang.String s = bs.toStringUtf8();
          columnName_ = s;
          return s;
        } else {
          return (java.lang.String) ref;
        }
      }
      /**
       * <code>string column_name = 10;</code>
       * @return The bytes for columnName.
       */
      public com.google.protobuf.ByteString
          getColumnNameBytes() {
        java.lang.Object ref = columnName_;
        if (ref instanceof String) {
          com.google.protobuf.ByteString b = 
              com.google.protobuf.ByteString.copyFromUtf8(
                  (java.lang.String) ref);
          columnName_ = b;
          return b;
        } else {
          return (com.google.protobuf.ByteString) ref;
        }
      }
      /**
       * <code>string column_name = 10;</code>
       * @param value The columnName to set.
       * @return This builder for chaining.
       */
      public Builder setColumnName(
          java.lang.String value) {
        if (value == null) {
    throw new NullPointerException();
  }
  
        columnName_ = value;
        onChanged();
        return this;
      }
      /**
       * <code>string column_name = 10;</code>
       * @return This builder for chaining.
       */
      public Builder clearColumnName() {
        
        columnName_ = getDefaultInstance().getColumnName();
        onChanged();
        return this;
      }
      /**
       * <code>string column_name = 10;</code>
       * @param value The bytes for columnName to set.
       * @return This builder for chaining.
       */
      public Builder setColumnNameBytes(
          com.google.protobuf.ByteString value) {
        if (value == null) {
    throw new NullPointerException();
  }
  checkByteStringIsUtf8(value);
        
        columnName_ = value;
        onChanged();
        return this;
      }

      private java.lang.Object schemaName_ = "";
      /**
       * <code>string schema_name = 11;</code>
       * @return The schemaName.
       */
      public java.lang.String getSchemaName() {
        java.lang.Object ref = schemaName_;
        if (!(ref instanceof java.lang.String)) {
          com.google.protobuf.ByteString bs =
              (com.google.protobuf.ByteString) ref;
          java.lang.String s = bs.toStringUtf8();
          schemaName_ = s;
          return s;
        } else {
          return (java.lang.String) ref;
        }
      }
      /**
       * <code>string schema_name = 11;</code>
       * @return The bytes for schemaName.
       */
      public com.google.protobuf.ByteString
          getSchemaNameBytes() {
        java.lang.Object ref = schemaName_;
        if (ref instanceof String) {
          com.google.protobuf.ByteString b = 
              com.google.protobuf.ByteString.copyFromUtf8(
                  (java.lang.String) ref);
          schemaName_ = b;
          return b;
        } else {
          return (com.google.protobuf.ByteString) ref;
        }
      }
      /**
       * <code>string schema_name = 11;</code>
       * @param value The schemaName to set.
       * @return This builder for chaining.
       */
      public Builder setSchemaName(
          java.lang.String value) {
        if (value == null) {
    throw new NullPointerException();
  }
  
        schemaName_ = value;
        onChanged();
        return this;
      }
      /**
       * <code>string schema_name = 11;</code>
       * @return This builder for chaining.
       */
      public Builder clearSchemaName() {
        
        schemaName_ = getDefaultInstance().getSchemaName();
        onChanged();
        return this;
      }
      /**
       * <code>string schema_name = 11;</code>
       * @param value The bytes for schemaName to set.
       * @return This builder for chaining.
       */
      public Builder setSchemaNameBytes(
          com.google.protobuf.ByteString value) {
        if (value == null) {
    throw new NullPointerException();
  }
  checkByteStringIsUtf8(value);
        
        schemaName_ = value;
        onChanged();
        return this;
      }

      private int precision_ ;
      /**
       * <code>uint32 precision = 12;</code>
       * @return The precision.
       */
      @java.lang.Override
      public int getPrecision() {
        return precision_;
      }
      /**
       * <code>uint32 precision = 12;</code>
       * @param value The precision to set.
       * @return This builder for chaining.
       */
      public Builder setPrecision(int value) {
        
        precision_ = value;
        onChanged();
        return this;
      }
      /**
       * <code>uint32 precision = 12;</code>
       * @return This builder for chaining.
       */
      public Builder clearPrecision() {
        
        precision_ = 0;
        onChanged();
        return this;
      }

      private int scale_ ;
      /**
       * <code>uint32 scale = 13;</code>
       * @return The scale.
       */
      @java.lang.Override
      public int getScale() {
        return scale_;
      }
      /**
       * <code>uint32 scale = 13;</code>
       * @param value The scale to set.
       * @return This builder for chaining.
       */
      public Builder setScale(int value) {
        
        scale_ = value;
        onChanged();
        return this;
      }
      /**
       * <code>uint32 scale = 13;</code>
       * @return This builder for chaining.
       */
      public Builder clearScale() {
        
        scale_ = 0;
        onChanged();
        return this;
      }

      private java.lang.Object tableName_ = "";
      /**
       * <code>string table_name = 14;</code>
       * @return The tableName.
       */
      public java.lang.String getTableName() {
        java.lang.Object ref = tableName_;
        if (!(ref instanceof java.lang.String)) {
          com.google.protobuf.ByteString bs =
              (com.google.protobuf.ByteString) ref;
          java.lang.String s = bs.toStringUtf8();
          tableName_ = s;
          return s;
        } else {
          return (java.lang.String) ref;
        }
      }
      /**
       * <code>string table_name = 14;</code>
       * @return The bytes for tableName.
       */
      public com.google.protobuf.ByteString
          getTableNameBytes() {
        java.lang.Object ref = tableName_;
        if (ref instanceof String) {
          com.google.protobuf.ByteString b = 
              com.google.protobuf.ByteString.copyFromUtf8(
                  (java.lang.String) ref);
          tableName_ = b;
          return b;
        } else {
          return (com.google.protobuf.ByteString) ref;
        }
      }
      /**
       * <code>string table_name = 14;</code>
       * @param value The tableName to set.
       * @return This builder for chaining.
       */
      public Builder setTableName(
          java.lang.String value) {
        if (value == null) {
    throw new NullPointerException();
  }
  
        tableName_ = value;
        onChanged();
        return this;
      }
      /**
       * <code>string table_name = 14;</code>
       * @return This builder for chaining.
       */
      public Builder clearTableName() {
        
        tableName_ = getDefaultInstance().getTableName();
        onChanged();
        return this;
      }
      /**
       * <code>string table_name = 14;</code>
       * @param value The bytes for tableName to set.
       * @return This builder for chaining.
       */
      public Builder setTableNameBytes(
          com.google.protobuf.ByteString value) {
        if (value == null) {
    throw new NullPointerException();
  }
  checkByteStringIsUtf8(value);
        
        tableName_ = value;
        onChanged();
        return this;
      }

      private java.lang.Object catalogName_ = "";
      /**
       * <code>string catalog_name = 15;</code>
       * @return The catalogName.
       */
      public java.lang.String getCatalogName() {
        java.lang.Object ref = catalogName_;
        if (!(ref instanceof java.lang.String)) {
          com.google.protobuf.ByteString bs =
              (com.google.protobuf.ByteString) ref;
          java.lang.String s = bs.toStringUtf8();
          catalogName_ = s;
          return s;
        } else {
          return (java.lang.String) ref;
        }
      }
      /**
       * <code>string catalog_name = 15;</code>
       * @return The bytes for catalogName.
       */
      public com.google.protobuf.ByteString
          getCatalogNameBytes() {
        java.lang.Object ref = catalogName_;
        if (ref instanceof String) {
          com.google.protobuf.ByteString b = 
              com.google.protobuf.ByteString.copyFromUtf8(
                  (java.lang.String) ref);
          catalogName_ = b;
          return b;
        } else {
          return (com.google.protobuf.ByteString) ref;
        }
      }
      /**
       * <code>string catalog_name = 15;</code>
       * @param value The catalogName to set.
       * @return This builder for chaining.
       */
      public Builder setCatalogName(
          java.lang.String value) {
        if (value == null) {
    throw new NullPointerException();
  }
  
        catalogName_ = value;
        onChanged();
        return this;
      }
      /**
       * <code>string catalog_name = 15;</code>
       * @return This builder for chaining.
       */
      public Builder clearCatalogName() {
        
        catalogName_ = getDefaultInstance().getCatalogName();
        onChanged();
        return this;
      }
      /**
       * <code>string catalog_name = 15;</code>
       * @param value The bytes for catalogName to set.
       * @return This builder for chaining.
       */
      public Builder setCatalogNameBytes(
          com.google.protobuf.ByteString value) {
        if (value == null) {
    throw new NullPointerException();
  }
  checkByteStringIsUtf8(value);
        
        catalogName_ = value;
        onChanged();
        return this;
      }

      private boolean readOnly_ ;
      /**
       * <code>bool read_only = 16;</code>
       * @return The readOnly.
       */
      @java.lang.Override
      public boolean getReadOnly() {
        return readOnly_;
      }
      /**
       * <code>bool read_only = 16;</code>
       * @param value The readOnly to set.
       * @return This builder for chaining.
       */
      public Builder setReadOnly(boolean value) {
        
        readOnly_ = value;
        onChanged();
        return this;
      }
      /**
       * <code>bool read_only = 16;</code>
       * @return This builder for chaining.
       */
      public Builder clearReadOnly() {
        
        readOnly_ = false;
        onChanged();
        return this;
      }

      private boolean writable_ ;
      /**
       * <code>bool writable = 17;</code>
       * @return The writable.
       */
      @java.lang.Override
      public boolean getWritable() {
        return writable_;
      }
      /**
       * <code>bool writable = 17;</code>
       * @param value The writable to set.
       * @return This builder for chaining.
       */
      public Builder setWritable(boolean value) {
        
        writable_ = value;
        onChanged();
        return this;
      }
      /**
       * <code>bool writable = 17;</code>
       * @return This builder for chaining.
       */
      public Builder clearWritable() {
        
        writable_ = false;
        onChanged();
        return this;
      }

      private boolean definitelyWritable_ ;
      /**
       * <code>bool definitely_writable = 18;</code>
       * @return The definitelyWritable.
       */
      @java.lang.Override
      public boolean getDefinitelyWritable() {
        return definitelyWritable_;
      }
      /**
       * <code>bool definitely_writable = 18;</code>
       * @param value The definitelyWritable to set.
       * @return This builder for chaining.
       */
      public Builder setDefinitelyWritable(boolean value) {
        
        definitelyWritable_ = value;
        onChanged();
        return this;
      }
      /**
       * <code>bool definitely_writable = 18;</code>
       * @return This builder for chaining.
       */
      public Builder clearDefinitelyWritable() {
        
        definitelyWritable_ = false;
        onChanged();
        return this;
      }

      private java.lang.Object columnClassName_ = "";
      /**
       * <code>string column_class_name = 19;</code>
       * @return The columnClassName.
       */
      public java.lang.String getColumnClassName() {
        java.lang.Object ref = columnClassName_;
        if (!(ref instanceof java.lang.String)) {
          com.google.protobuf.ByteString bs =
              (com.google.protobuf.ByteString) ref;
          java.lang.String s = bs.toStringUtf8();
          columnClassName_ = s;
          return s;
        } else {
          return (java.lang.String) ref;
        }
      }
      /**
       * <code>string column_class_name = 19;</code>
       * @return The bytes for columnClassName.
       */
      public com.google.protobuf.ByteString
          getColumnClassNameBytes() {
        java.lang.Object ref = columnClassName_;
        if (ref instanceof String) {
          com.google.protobuf.ByteString b = 
              com.google.protobuf.ByteString.copyFromUtf8(
                  (java.lang.String) ref);
          columnClassName_ = b;
          return b;
        } else {
          return (com.google.protobuf.ByteString) ref;
        }
      }
      /**
       * <code>string column_class_name = 19;</code>
       * @param value The columnClassName to set.
       * @return This builder for chaining.
       */
      public Builder setColumnClassName(
          java.lang.String value) {
        if (value == null) {
    throw new NullPointerException();
  }
  
        columnClassName_ = value;
        onChanged();
        return this;
      }
      /**
       * <code>string column_class_name = 19;</code>
       * @return This builder for chaining.
       */
      public Builder clearColumnClassName() {
        
        columnClassName_ = getDefaultInstance().getColumnClassName();
        onChanged();
        return this;
      }
      /**
       * <code>string column_class_name = 19;</code>
       * @param value The bytes for columnClassName to set.
       * @return This builder for chaining.
       */
      public Builder setColumnClassNameBytes(
          com.google.protobuf.ByteString value) {
        if (value == null) {
    throw new NullPointerException();
  }
  checkByteStringIsUtf8(value);
        
        columnClassName_ = value;
        onChanged();
        return this;
      }

      private org.apache.calcite.avatica.proto.Common.AvaticaType type_;
      private com.google.protobuf.SingleFieldBuilderV3<
          org.apache.calcite.avatica.proto.Common.AvaticaType, org.apache.calcite.avatica.proto.Common.AvaticaType.Builder, org.apache.calcite.avatica.proto.Common.AvaticaTypeOrBuilder> typeBuilder_;
      /**
       * <code>.AvaticaType type = 20;</code>
       * @return Whether the type field is set.
       */
      public boolean hasType() {
        return typeBuilder_ != null || type_ != null;
      }
      /**
       * <code>.AvaticaType type = 20;</code>
       * @return The type.
       */
      public org.apache.calcite.avatica.proto.Common.AvaticaType getType() {
        if (typeBuilder_ == null) {
          return type_ == null ? org.apache.calcite.avatica.proto.Common.AvaticaType.getDefaultInstance() : type_;
        } else {
          return typeBuilder_.getMessage();
        }
      }
      /**
       * <code>.AvaticaType type = 20;</code>
       */
      public Builder setType(org.apache.calcite.avatica.proto.Common.AvaticaType value) {
        if (typeBuilder_ == null) {
          if (value == null) {
            throw new NullPointerException();
          }
          type_ = value;
          onChanged();
        } else {
          typeBuilder_.setMessage(value);
        }

        return this;
      }
      /**
       * <code>.AvaticaType type = 20;</code>
       */
      public Builder setType(
          org.apache.calcite.avatica.proto.Common.AvaticaType.Builder builderForValue) {
        if (typeBuilder_ == null) {
          type_ = builderForValue.build();
          onChanged();
        } else {
          typeBuilder_.setMessage(builderForValue.build());
        }

        return this;
      }
      /**
       * <code>.AvaticaType type = 20;</code>
       */
      public Builder mergeType(org.apache.calcite.avatica.proto.Common.AvaticaType value) {
        if (typeBuilder_ == null) {
          if (type_ != null) {
            type_ =
              org.apache.calcite.avatica.proto.Common.AvaticaType.newBuilder(type_).mergeFrom(value).buildPartial();
          } else {
            type_ = value;
          }
          onChanged();
        } else {
          typeBuilder_.mergeFrom(value);
        }

        return this;
      }
      /**
       * <code>.AvaticaType type = 20;</code>
       */
      public Builder clearType() {
        if (typeBuilder_ == null) {
          type_ = null;
          onChanged();
        } else {
          type_ = null;
          typeBuilder_ = null;
        }

        return this;
      }
      /**
       * <code>.AvaticaType type = 20;</code>
       */
      public org.apache.calcite.avatica.proto.Common.AvaticaType.Builder getTypeBuilder() {
        
        onChanged();
        return getTypeFieldBuilder().getBuilder();
      }
      /**
       * <code>.AvaticaType type = 20;</code>
       */
      public org.apache.calcite.avatica.proto.Common.AvaticaTypeOrBuilder getTypeOrBuilder() {
        if (typeBuilder_ != null) {
          return typeBuilder_.getMessageOrBuilder();
        } else {
          return type_ == null ?
              org.apache.calcite.avatica.proto.Common.AvaticaType.getDefaultInstance() : type_;
        }
      }
      /**
       * <code>.AvaticaType type = 20;</code>
       */
      private com.google.protobuf.SingleFieldBuilderV3<
          org.apache.calcite.avatica.proto.Common.AvaticaType, org.apache.calcite.avatica.proto.Common.AvaticaType.Builder, org.apache.calcite.avatica.proto.Common.AvaticaTypeOrBuilder> 
          getTypeFieldBuilder() {
        if (typeBuilder_ == null) {
          typeBuilder_ = new com.google.protobuf.SingleFieldBuilderV3<
              org.apache.calcite.avatica.proto.Common.AvaticaType, org.apache.calcite.avatica.proto.Common.AvaticaType.Builder, org.apache.calcite.avatica.proto.Common.AvaticaTypeOrBuilder>(
                  getType(),
                  getParentForChildren(),
                  isClean());
          type_ = null;
        }
        return typeBuilder_;
      }
      @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:ColumnMetaData)
    }

    // @@protoc_insertion_point(class_scope:ColumnMetaData)
    private static final org.apache.calcite.avatica.proto.Common.ColumnMetaData DEFAULT_INSTANCE;
    static {
      DEFAULT_INSTANCE = new org.apache.calcite.avatica.proto.Common.ColumnMetaData();
    }

    public static org.apache.calcite.avatica.proto.Common.ColumnMetaData getDefaultInstance() {
      return DEFAULT_INSTANCE;
    }

    private static final com.google.protobuf.Parser<ColumnMetaData>
        PARSER = new com.google.protobuf.AbstractParser<ColumnMetaData>() {
      @java.lang.Override
      public ColumnMetaData 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<ColumnMetaData> parser() {
      return PARSER;
    }

    @java.lang.Override
    public com.google.protobuf.Parser<ColumnMetaData> getParserForType() {
      return PARSER;
    }

    @java.lang.Override
    public org.apache.calcite.avatica.proto.Common.ColumnMetaData getDefaultInstanceForType() {
      return DEFAULT_INSTANCE;
    }

  }

  public interface AvaticaTypeOrBuilder extends
      // @@protoc_insertion_point(interface_extends:AvaticaType)
      com.google.protobuf.MessageOrBuilder {

    /**
     * <code>uint32 id = 1;</code>
     * @return The id.
     */
    int getId();

    /**
     * <code>string name = 2;</code>
     * @return The name.
     */
    java.lang.String getName();
    /**
     * <code>string name = 2;</code>
     * @return The bytes for name.
     */
    com.google.protobuf.ByteString
        getNameBytes();

    /**
     * <code>.Rep rep = 3;</code>
     * @return The enum numeric value on the wire for rep.
     */
    int getRepValue();
    /**
     * <code>.Rep rep = 3;</code>
     * @return The rep.
     */
    org.apache.calcite.avatica.proto.Common.Rep getRep();

    /**
     * <pre>
     * Only present when name = STRUCT
     * </pre>
     *
     * <code>repeated .ColumnMetaData columns = 4;</code>
     */
    java.util.List<org.apache.calcite.avatica.proto.Common.ColumnMetaData> 
        getColumnsList();
    /**
     * <pre>
     * Only present when name = STRUCT
     * </pre>
     *
     * <code>repeated .ColumnMetaData columns = 4;</code>
     */
    org.apache.calcite.avatica.proto.Common.ColumnMetaData getColumns(int index);
    /**
     * <pre>
     * Only present when name = STRUCT
     * </pre>
     *
     * <code>repeated .ColumnMetaData columns = 4;</code>
     */
    int getColumnsCount();
    /**
     * <pre>
     * Only present when name = STRUCT
     * </pre>
     *
     * <code>repeated .ColumnMetaData columns = 4;</code>
     */
    java.util.List<? extends org.apache.calcite.avatica.proto.Common.ColumnMetaDataOrBuilder> 
        getColumnsOrBuilderList();
    /**
     * <pre>
     * Only present when name = STRUCT
     * </pre>
     *
     * <code>repeated .ColumnMetaData columns = 4;</code>
     */
    org.apache.calcite.avatica.proto.Common.ColumnMetaDataOrBuilder getColumnsOrBuilder(
        int index);

    /**
     * <pre>
     * Only present when name = ARRAY
     * </pre>
     *
     * <code>.AvaticaType component = 5;</code>
     * @return Whether the component field is set.
     */
    boolean hasComponent();
    /**
     * <pre>
     * Only present when name = ARRAY
     * </pre>
     *
     * <code>.AvaticaType component = 5;</code>
     * @return The component.
     */
    org.apache.calcite.avatica.proto.Common.AvaticaType getComponent();
    /**
     * <pre>
     * Only present when name = ARRAY
     * </pre>
     *
     * <code>.AvaticaType component = 5;</code>
     */
    org.apache.calcite.avatica.proto.Common.AvaticaTypeOrBuilder getComponentOrBuilder();
  }
  /**
   * <pre>
   * Base class for a column type
   * </pre>
   *
   * Protobuf type {@code AvaticaType}
   */
  public static final class AvaticaType extends
      com.google.protobuf.GeneratedMessageV3 implements
      // @@protoc_insertion_point(message_implements:AvaticaType)
      AvaticaTypeOrBuilder {
  private static final long serialVersionUID = 0L;
    // Use AvaticaType.newBuilder() to construct.
    private AvaticaType(com.google.protobuf.GeneratedMessageV3.Builder<?> builder) {
      super(builder);
    }
    private AvaticaType() {
      name_ = "";
      rep_ = 0;
      columns_ = java.util.Collections.emptyList();
    }

    @java.lang.Override
    @SuppressWarnings({"unused"})
    protected java.lang.Object newInstance(
        UnusedPrivateParameter unused) {
      return new AvaticaType();
    }

    @java.lang.Override
    public final com.google.protobuf.UnknownFieldSet
    getUnknownFields() {
      return this.unknownFields;
    }
    public static final com.google.protobuf.Descriptors.Descriptor
        getDescriptor() {
      return org.apache.calcite.avatica.proto.Common.internal_static_AvaticaType_descriptor;
    }

    @java.lang.Override
    protected com.google.protobuf.GeneratedMessageV3.FieldAccessorTable
        internalGetFieldAccessorTable() {
      return org.apache.calcite.avatica.proto.Common.internal_static_AvaticaType_fieldAccessorTable
          .ensureFieldAccessorsInitialized(
              org.apache.calcite.avatica.proto.Common.AvaticaType.class, org.apache.calcite.avatica.proto.Common.AvaticaType.Builder.class);
    }

    public static final int ID_FIELD_NUMBER = 1;
    private int id_;
    /**
     * <code>uint32 id = 1;</code>
     * @return The id.
     */
    @java.lang.Override
    public int getId() {
      return id_;
    }

    public static final int NAME_FIELD_NUMBER = 2;
    private volatile java.lang.Object name_;
    /**
     * <code>string name = 2;</code>
     * @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();
        name_ = s;
        return s;
      }
    }
    /**
     * <code>string name = 2;</code>
     * @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 REP_FIELD_NUMBER = 3;
    private int rep_;
    /**
     * <code>.Rep rep = 3;</code>
     * @return The enum numeric value on the wire for rep.
     */
    @java.lang.Override public int getRepValue() {
      return rep_;
    }
    /**
     * <code>.Rep rep = 3;</code>
     * @return The rep.
     */
    @java.lang.Override public org.apache.calcite.avatica.proto.Common.Rep getRep() {
      @SuppressWarnings("deprecation")
      org.apache.calcite.avatica.proto.Common.Rep result = org.apache.calcite.avatica.proto.Common.Rep.valueOf(rep_);
      return result == null ? org.apache.calcite.avatica.proto.Common.Rep.UNRECOGNIZED : result;
    }

    public static final int COLUMNS_FIELD_NUMBER = 4;
    private java.util.List<org.apache.calcite.avatica.proto.Common.ColumnMetaData> columns_;
    /**
     * <pre>
     * Only present when name = STRUCT
     * </pre>
     *
     * <code>repeated .ColumnMetaData columns = 4;</code>
     */
    @java.lang.Override
    public java.util.List<org.apache.calcite.avatica.proto.Common.ColumnMetaData> getColumnsList() {
      return columns_;
    }
    /**
     * <pre>
     * Only present when name = STRUCT
     * </pre>
     *
     * <code>repeated .ColumnMetaData columns = 4;</code>
     */
    @java.lang.Override
    public java.util.List<? extends org.apache.calcite.avatica.proto.Common.ColumnMetaDataOrBuilder> 
        getColumnsOrBuilderList() {
      return columns_;
    }
    /**
     * <pre>
     * Only present when name = STRUCT
     * </pre>
     *
     * <code>repeated .ColumnMetaData columns = 4;</code>
     */
    @java.lang.Override
    public int getColumnsCount() {
      return columns_.size();
    }
    /**
     * <pre>
     * Only present when name = STRUCT
     * </pre>
     *
     * <code>repeated .ColumnMetaData columns = 4;</code>
     */
    @java.lang.Override
    public org.apache.calcite.avatica.proto.Common.ColumnMetaData getColumns(int index) {
      return columns_.get(index);
    }
    /**
     * <pre>
     * Only present when name = STRUCT
     * </pre>
     *
     * <code>repeated .ColumnMetaData columns = 4;</code>
     */
    @java.lang.Override
    public org.apache.calcite.avatica.proto.Common.ColumnMetaDataOrBuilder getColumnsOrBuilder(
        int index) {
      return columns_.get(index);
    }

    public static final int COMPONENT_FIELD_NUMBER = 5;
    private org.apache.calcite.avatica.proto.Common.AvaticaType component_;
    /**
     * <pre>
     * Only present when name = ARRAY
     * </pre>
     *
     * <code>.AvaticaType component = 5;</code>
     * @return Whether the component field is set.
     */
    @java.lang.Override
    public boolean hasComponent() {
      return component_ != null;
    }
    /**
     * <pre>
     * Only present when name = ARRAY
     * </pre>
     *
     * <code>.AvaticaType component = 5;</code>
     * @return The component.
     */
    @java.lang.Override
    public org.apache.calcite.avatica.proto.Common.AvaticaType getComponent() {
      return component_ == null ? org.apache.calcite.avatica.proto.Common.AvaticaType.getDefaultInstance() : component_;
    }
    /**
     * <pre>
     * Only present when name = ARRAY
     * </pre>
     *
     * <code>.AvaticaType component = 5;</code>
     */
    @java.lang.Override
    public org.apache.calcite.avatica.proto.Common.AvaticaTypeOrBuilder getComponentOrBuilder() {
      return getComponent();
    }

    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 (id_ != 0) {
        output.writeUInt32(1, id_);
      }
      if (!com.google.protobuf.GeneratedMessageV3.isStringEmpty(name_)) {
        com.google.protobuf.GeneratedMessageV3.writeString(output, 2, name_);
      }
      if (rep_ != org.apache.calcite.avatica.proto.Common.Rep.PRIMITIVE_BOOLEAN.getNumber()) {
        output.writeEnum(3, rep_);
      }
      for (int i = 0; i < columns_.size(); i++) {
        output.writeMessage(4, columns_.get(i));
      }
      if (component_ != null) {
        output.writeMessage(5, getComponent());
      }
      getUnknownFields().writeTo(output);
    }

    @java.lang.Override
    public int getSerializedSize() {
      int size = memoizedSize;
      if (size != -1) return size;

      size = 0;
      if (id_ != 0) {
        size += com.google.protobuf.CodedOutputStream
          .computeUInt32Size(1, id_);
      }
      if (!com.google.protobuf.GeneratedMessageV3.isStringEmpty(name_)) {
        size += com.google.protobuf.GeneratedMessageV3.computeStringSize(2, name_);
      }
      if (rep_ != org.apache.calcite.avatica.proto.Common.Rep.PRIMITIVE_BOOLEAN.getNumber()) {
        size += com.google.protobuf.CodedOutputStream
          .computeEnumSize(3, rep_);
      }
      for (int i = 0; i < columns_.size(); i++) {
        size += com.google.protobuf.CodedOutputStream
          .computeMessageSize(4, columns_.get(i));
      }
      if (component_ != null) {
        size += com.google.protobuf.CodedOutputStream
          .computeMessageSize(5, getComponent());
      }
      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 org.apache.calcite.avatica.proto.Common.AvaticaType)) {
        return super.equals(obj);
      }
      org.apache.calcite.avatica.proto.Common.AvaticaType other = (org.apache.calcite.avatica.proto.Common.AvaticaType) obj;

      if (getId()
          != other.getId()) return false;
      if (!getName()
          .equals(other.getName())) return false;
      if (rep_ != other.rep_) return false;
      if (!getColumnsList()
          .equals(other.getColumnsList())) return false;
      if (hasComponent() != other.hasComponent()) return false;
      if (hasComponent()) {
        if (!getComponent()
            .equals(other.getComponent())) 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();
      hash = (37 * hash) + ID_FIELD_NUMBER;
      hash = (53 * hash) + getId();
      hash = (37 * hash) + NAME_FIELD_NUMBER;
      hash = (53 * hash) + getName().hashCode();
      hash = (37 * hash) + REP_FIELD_NUMBER;
      hash = (53 * hash) + rep_;
      if (getColumnsCount() > 0) {
        hash = (37 * hash) + COLUMNS_FIELD_NUMBER;
        hash = (53 * hash) + getColumnsList().hashCode();
      }
      if (hasComponent()) {
        hash = (37 * hash) + COMPONENT_FIELD_NUMBER;
        hash = (53 * hash) + getComponent().hashCode();
      }
      hash = (29 * hash) + getUnknownFields().hashCode();
      memoizedHashCode = hash;
      return hash;
    }

    public static org.apache.calcite.avatica.proto.Common.AvaticaType parseFrom(
        java.nio.ByteBuffer data)
        throws com.google.protobuf.InvalidProtocolBufferException {
      return PARSER.parseFrom(data);
    }
    public static org.apache.calcite.avatica.proto.Common.AvaticaType parseFrom(
        java.nio.ByteBuffer data,
        com.google.protobuf.ExtensionRegistryLite extensionRegistry)
        throws com.google.protobuf.InvalidProtocolBufferException {
      return PARSER.parseFrom(data, extensionRegistry);
    }
    public static org.apache.calcite.avatica.proto.Common.AvaticaType parseFrom(
        com.google.protobuf.ByteString data)
        throws com.google.protobuf.InvalidProtocolBufferException {
      return PARSER.parseFrom(data);
    }
    public static org.apache.calcite.avatica.proto.Common.AvaticaType parseFrom(
        com.google.protobuf.ByteString data,
        com.google.protobuf.ExtensionRegistryLite extensionRegistry)
        throws com.google.protobuf.InvalidProtocolBufferException {
      return PARSER.parseFrom(data, extensionRegistry);
    }
    public static org.apache.calcite.avatica.proto.Common.AvaticaType parseFrom(byte[] data)
        throws com.google.protobuf.InvalidProtocolBufferException {
      return PARSER.parseFrom(data);
    }
    public static org.apache.calcite.avatica.proto.Common.AvaticaType parseFrom(
        byte[] data,
        com.google.protobuf.ExtensionRegistryLite extensionRegistry)
        throws com.google.protobuf.InvalidProtocolBufferException {
      return PARSER.parseFrom(data, extensionRegistry);
    }
    public static org.apache.calcite.avatica.proto.Common.AvaticaType parseFrom(java.io.InputStream input)
        throws java.io.IOException {
      return com.google.protobuf.GeneratedMessageV3
          .parseWithIOException(PARSER, input);
    }
    public static org.apache.calcite.avatica.proto.Common.AvaticaType 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 org.apache.calcite.avatica.proto.Common.AvaticaType parseDelimitedFrom(java.io.InputStream input)
        throws java.io.IOException {
      return com.google.protobuf.GeneratedMessageV3
          .parseDelimitedWithIOException(PARSER, input);
    }
    public static org.apache.calcite.avatica.proto.Common.AvaticaType 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 org.apache.calcite.avatica.proto.Common.AvaticaType parseFrom(
        com.google.protobuf.CodedInputStream input)
        throws java.io.IOException {
      return com.google.protobuf.GeneratedMessageV3
          .parseWithIOException(PARSER, input);
    }
    public static org.apache.calcite.avatica.proto.Common.AvaticaType 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(org.apache.calcite.avatica.proto.Common.AvaticaType 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;
    }
    /**
     * <pre>
     * Base class for a column type
     * </pre>
     *
     * Protobuf type {@code AvaticaType}
     */
    public static final class Builder extends
        com.google.protobuf.GeneratedMessageV3.Builder<Builder> implements
        // @@protoc_insertion_point(builder_implements:AvaticaType)
        org.apache.calcite.avatica.proto.Common.AvaticaTypeOrBuilder {
      public static final com.google.protobuf.Descriptors.Descriptor
          getDescriptor() {
        return org.apache.calcite.avatica.proto.Common.internal_static_AvaticaType_descriptor;
      }

      @java.lang.Override
      protected com.google.protobuf.GeneratedMessageV3.FieldAccessorTable
          internalGetFieldAccessorTable() {
        return org.apache.calcite.avatica.proto.Common.internal_static_AvaticaType_fieldAccessorTable
            .ensureFieldAccessorsInitialized(
                org.apache.calcite.avatica.proto.Common.AvaticaType.class, org.apache.calcite.avatica.proto.Common.AvaticaType.Builder.class);
      }

      // Construct using org.apache.calcite.avatica.proto.Common.AvaticaType.newBuilder()
      private Builder() {

      }

      private Builder(
          com.google.protobuf.GeneratedMessageV3.BuilderParent parent) {
        super(parent);

      }
      @java.lang.Override
      public Builder clear() {
        super.clear();
        id_ = 0;

        name_ = "";

        rep_ = 0;

        if (columnsBuilder_ == null) {
          columns_ = java.util.Collections.emptyList();
        } else {
          columns_ = null;
          columnsBuilder_.clear();
        }
        bitField0_ = (bitField0_ & ~0x00000001);
        if (componentBuilder_ == null) {
          component_ = null;
        } else {
          component_ = null;
          componentBuilder_ = null;
        }
        return this;
      }

      @java.lang.Override
      public com.google.protobuf.Descriptors.Descriptor
          getDescriptorForType() {
        return org.apache.calcite.avatica.proto.Common.internal_static_AvaticaType_descriptor;
      }

      @java.lang.Override
      public org.apache.calcite.avatica.proto.Common.AvaticaType getDefaultInstanceForType() {
        return org.apache.calcite.avatica.proto.Common.AvaticaType.getDefaultInstance();
      }

      @java.lang.Override
      public org.apache.calcite.avatica.proto.Common.AvaticaType build() {
        org.apache.calcite.avatica.proto.Common.AvaticaType result = buildPartial();
        if (!result.isInitialized()) {
          throw newUninitializedMessageException(result);
        }
        return result;
      }

      @java.lang.Override
      public org.apache.calcite.avatica.proto.Common.AvaticaType buildPartial() {
        org.apache.calcite.avatica.proto.Common.AvaticaType result = new org.apache.calcite.avatica.proto.Common.AvaticaType(this);
        int from_bitField0_ = bitField0_;
        result.id_ = id_;
        result.name_ = name_;
        result.rep_ = rep_;
        if (columnsBuilder_ == null) {
          if (((bitField0_ & 0x00000001) != 0)) {
            columns_ = java.util.Collections.unmodifiableList(columns_);
            bitField0_ = (bitField0_ & ~0x00000001);
          }
          result.columns_ = columns_;
        } else {
          result.columns_ = columnsBuilder_.build();
        }
        if (componentBuilder_ == null) {
          result.component_ = component_;
        } else {
          result.component_ = componentBuilder_.build();
        }
        onBuilt();
        return result;
      }

      @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 org.apache.calcite.avatica.proto.Common.AvaticaType) {
          return mergeFrom((org.apache.calcite.avatica.proto.Common.AvaticaType)other);
        } else {
          super.mergeFrom(other);
          return this;
        }
      }

      public Builder mergeFrom(org.apache.calcite.avatica.proto.Common.AvaticaType other) {
        if (other == org.apache.calcite.avatica.proto.Common.AvaticaType.getDefaultInstance()) return this;
        if (other.getId() != 0) {
          setId(other.getId());
        }
        if (!other.getName().isEmpty()) {
          name_ = other.name_;
          onChanged();
        }
        if (other.rep_ != 0) {
          setRepValue(other.getRepValue());
        }
        if (columnsBuilder_ == null) {
          if (!other.columns_.isEmpty()) {
            if (columns_.isEmpty()) {
              columns_ = other.columns_;
              bitField0_ = (bitField0_ & ~0x00000001);
            } else {
              ensureColumnsIsMutable();
              columns_.addAll(other.columns_);
            }
            onChanged();
          }
        } else {
          if (!other.columns_.isEmpty()) {
            if (columnsBuilder_.isEmpty()) {
              columnsBuilder_.dispose();
              columnsBuilder_ = null;
              columns_ = other.columns_;
              bitField0_ = (bitField0_ & ~0x00000001);
              columnsBuilder_ = 
                com.google.protobuf.GeneratedMessageV3.alwaysUseFieldBuilders ?
                   getColumnsFieldBuilder() : null;
            } else {
              columnsBuilder_.addAllMessages(other.columns_);
            }
          }
        }
        if (other.hasComponent()) {
          mergeComponent(other.getComponent());
        }
        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: {
                id_ = input.readUInt32();

                break;
              } // case 8
              case 18: {
                name_ = input.readStringRequireUtf8();

                break;
              } // case 18
              case 24: {
                rep_ = input.readEnum();

                break;
              } // case 24
              case 34: {
                org.apache.calcite.avatica.proto.Common.ColumnMetaData m =
                    input.readMessage(
                        org.apache.calcite.avatica.proto.Common.ColumnMetaData.parser(),
                        extensionRegistry);
                if (columnsBuilder_ == null) {
                  ensureColumnsIsMutable();
                  columns_.add(m);
                } else {
                  columnsBuilder_.addMessage(m);
                }
                break;
              } // case 34
              case 42: {
                input.readMessage(
                    getComponentFieldBuilder().getBuilder(),
                    extensionRegistry);

                break;
              } // case 42
              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 id_ ;
      /**
       * <code>uint32 id = 1;</code>
       * @return The id.
       */
      @java.lang.Override
      public int getId() {
        return id_;
      }
      /**
       * <code>uint32 id = 1;</code>
       * @param value The id to set.
       * @return This builder for chaining.
       */
      public Builder setId(int value) {
        
        id_ = value;
        onChanged();
        return this;
      }
      /**
       * <code>uint32 id = 1;</code>
       * @return This builder for chaining.
       */
      public Builder clearId() {
        
        id_ = 0;
        onChanged();
        return this;
      }

      private java.lang.Object name_ = "";
      /**
       * <code>string name = 2;</code>
       * @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();
          name_ = s;
          return s;
        } else {
          return (java.lang.String) ref;
        }
      }
      /**
       * <code>string name = 2;</code>
       * @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;
        }
      }
      /**
       * <code>string name = 2;</code>
       * @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;
        onChanged();
        return this;
      }
      /**
       * <code>string name = 2;</code>
       * @return This builder for chaining.
       */
      public Builder clearName() {
        
        name_ = getDefaultInstance().getName();
        onChanged();
        return this;
      }
      /**
       * <code>string name = 2;</code>
       * @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();
  }
  checkByteStringIsUtf8(value);
        
        name_ = value;
        onChanged();
        return this;
      }

      private int rep_ = 0;
      /**
       * <code>.Rep rep = 3;</code>
       * @return The enum numeric value on the wire for rep.
       */
      @java.lang.Override public int getRepValue() {
        return rep_;
      }
      /**
       * <code>.Rep rep = 3;</code>
       * @param value The enum numeric value on the wire for rep to set.
       * @return This builder for chaining.
       */
      public Builder setRepValue(int value) {
        
        rep_ = value;
        onChanged();
        return this;
      }
      /**
       * <code>.Rep rep = 3;</code>
       * @return The rep.
       */
      @java.lang.Override
      public org.apache.calcite.avatica.proto.Common.Rep getRep() {
        @SuppressWarnings("deprecation")
        org.apache.calcite.avatica.proto.Common.Rep result = org.apache.calcite.avatica.proto.Common.Rep.valueOf(rep_);
        return result == null ? org.apache.calcite.avatica.proto.Common.Rep.UNRECOGNIZED : result;
      }
      /**
       * <code>.Rep rep = 3;</code>
       * @param value The rep to set.
       * @return This builder for chaining.
       */
      public Builder setRep(org.apache.calcite.avatica.proto.Common.Rep value) {
        if (value == null) {
          throw new NullPointerException();
        }
        
        rep_ = value.getNumber();
        onChanged();
        return this;
      }
      /**
       * <code>.Rep rep = 3;</code>
       * @return This builder for chaining.
       */
      public Builder clearRep() {
        
        rep_ = 0;
        onChanged();
        return this;
      }

      private java.util.List<org.apache.calcite.avatica.proto.Common.ColumnMetaData> columns_ =
        java.util.Collections.emptyList();
      private void ensureColumnsIsMutable() {
        if (!((bitField0_ & 0x00000001) != 0)) {
          columns_ = new java.util.ArrayList<org.apache.calcite.avatica.proto.Common.ColumnMetaData>(columns_);
          bitField0_ |= 0x00000001;
         }
      }

      private com.google.protobuf.RepeatedFieldBuilderV3<
          org.apache.calcite.avatica.proto.Common.ColumnMetaData, org.apache.calcite.avatica.proto.Common.ColumnMetaData.Builder, org.apache.calcite.avatica.proto.Common.ColumnMetaDataOrBuilder> columnsBuilder_;

      /**
       * <pre>
       * Only present when name = STRUCT
       * </pre>
       *
       * <code>repeated .ColumnMetaData columns = 4;</code>
       */
      public java.util.List<org.apache.calcite.avatica.proto.Common.ColumnMetaData> getColumnsList() {
        if (columnsBuilder_ == null) {
          return java.util.Collections.unmodifiableList(columns_);
        } else {
          return columnsBuilder_.getMessageList();
        }
      }
      /**
       * <pre>
       * Only present when name = STRUCT
       * </pre>
       *
       * <code>repeated .ColumnMetaData columns = 4;</code>
       */
      public int getColumnsCount() {
        if (columnsBuilder_ == null) {
          return columns_.size();
        } else {
          return columnsBuilder_.getCount();
        }
      }
      /**
       * <pre>
       * Only present when name = STRUCT
       * </pre>
       *
       * <code>repeated .ColumnMetaData columns = 4;</code>
       */
      public org.apache.calcite.avatica.proto.Common.ColumnMetaData getColumns(int index) {
        if (columnsBuilder_ == null) {
          return columns_.get(index);
        } else {
          return columnsBuilder_.getMessage(index);
        }
      }
      /**
       * <pre>
       * Only present when name = STRUCT
       * </pre>
       *
       * <code>repeated .ColumnMetaData columns = 4;</code>
       */
      public Builder setColumns(
          int index, org.apache.calcite.avatica.proto.Common.ColumnMetaData value) {
        if (columnsBuilder_ == null) {
          if (value == null) {
            throw new NullPointerException();
          }
          ensureColumnsIsMutable();
          columns_.set(index, value);
          onChanged();
        } else {
          columnsBuilder_.setMessage(index, value);
        }
        return this;
      }
      /**
       * <pre>
       * Only present when name = STRUCT
       * </pre>
       *
       * <code>repeated .ColumnMetaData columns = 4;</code>
       */
      public Builder setColumns(
          int index, org.apache.calcite.avatica.proto.Common.ColumnMetaData.Builder builderForValue) {
        if (columnsBuilder_ == null) {
          ensureColumnsIsMutable();
          columns_.set(index, builderForValue.build());
          onChanged();
        } else {
          columnsBuilder_.setMessage(index, builderForValue.build());
        }
        return this;
      }
      /**
       * <pre>
       * Only present when name = STRUCT
       * </pre>
       *
       * <code>repeated .ColumnMetaData columns = 4;</code>
       */
      public Builder addColumns(org.apache.calcite.avatica.proto.Common.ColumnMetaData value) {
        if (columnsBuilder_ == null) {
          if (value == null) {
            throw new NullPointerException();
          }
          ensureColumnsIsMutable();
          columns_.add(value);
          onChanged();
        } else {
          columnsBuilder_.addMessage(value);
        }
        return this;
      }
      /**
       * <pre>
       * Only present when name = STRUCT
       * </pre>
       *
       * <code>repeated .ColumnMetaData columns = 4;</code>
       */
      public Builder addColumns(
          int index, org.apache.calcite.avatica.proto.Common.ColumnMetaData value) {
        if (columnsBuilder_ == null) {
          if (value == null) {
            throw new NullPointerException();
          }
          ensureColumnsIsMutable();
          columns_.add(index, value);
          onChanged();
        } else {
          columnsBuilder_.addMessage(index, value);
        }
        return this;
      }
      /**
       * <pre>
       * Only present when name = STRUCT
       * </pre>
       *
       * <code>repeated .ColumnMetaData columns = 4;</code>
       */
      public Builder addColumns(
          org.apache.calcite.avatica.proto.Common.ColumnMetaData.Builder builderForValue) {
        if (columnsBuilder_ == null) {
          ensureColumnsIsMutable();
          columns_.add(builderForValue.build());
          onChanged();
        } else {
          columnsBuilder_.addMessage(builderForValue.build());
        }
        return this;
      }
      /**
       * <pre>
       * Only present when name = STRUCT
       * </pre>
       *
       * <code>repeated .ColumnMetaData columns = 4;</code>
       */
      public Builder addColumns(
          int index, org.apache.calcite.avatica.proto.Common.ColumnMetaData.Builder builderForValue) {
        if (columnsBuilder_ == null) {
          ensureColumnsIsMutable();
          columns_.add(index, builderForValue.build());
          onChanged();
        } else {
          columnsBuilder_.addMessage(index, builderForValue.build());
        }
        return this;
      }
      /**
       * <pre>
       * Only present when name = STRUCT
       * </pre>
       *
       * <code>repeated .ColumnMetaData columns = 4;</code>
       */
      public Builder addAllColumns(
          java.lang.Iterable<? extends org.apache.calcite.avatica.proto.Common.ColumnMetaData> values) {
        if (columnsBuilder_ == null) {
          ensureColumnsIsMutable();
          com.google.protobuf.AbstractMessageLite.Builder.addAll(
              values, columns_);
          onChanged();
        } else {
          columnsBuilder_.addAllMessages(values);
        }
        return this;
      }
      /**
       * <pre>
       * Only present when name = STRUCT
       * </pre>
       *
       * <code>repeated .ColumnMetaData columns = 4;</code>
       */
      public Builder clearColumns() {
        if (columnsBuilder_ == null) {
          columns_ = java.util.Collections.emptyList();
          bitField0_ = (bitField0_ & ~0x00000001);
          onChanged();
        } else {
          columnsBuilder_.clear();
        }
        return this;
      }
      /**
       * <pre>
       * Only present when name = STRUCT
       * </pre>
       *
       * <code>repeated .ColumnMetaData columns = 4;</code>
       */
      public Builder removeColumns(int index) {
        if (columnsBuilder_ == null) {
          ensureColumnsIsMutable();
          columns_.remove(index);
          onChanged();
        } else {
          columnsBuilder_.remove(index);
        }
        return this;
      }
      /**
       * <pre>
       * Only present when name = STRUCT
       * </pre>
       *
       * <code>repeated .ColumnMetaData columns = 4;</code>
       */
      public org.apache.calcite.avatica.proto.Common.ColumnMetaData.Builder getColumnsBuilder(
          int index) {
        return getColumnsFieldBuilder().getBuilder(index);
      }
      /**
       * <pre>
       * Only present when name = STRUCT
       * </pre>
       *
       * <code>repeated .ColumnMetaData columns = 4;</code>
       */
      public org.apache.calcite.avatica.proto.Common.ColumnMetaDataOrBuilder getColumnsOrBuilder(
          int index) {
        if (columnsBuilder_ == null) {
          return columns_.get(index);  } else {
          return columnsBuilder_.getMessageOrBuilder(index);
        }
      }
      /**
       * <pre>
       * Only present when name = STRUCT
       * </pre>
       *
       * <code>repeated .ColumnMetaData columns = 4;</code>
       */
      public java.util.List<? extends org.apache.calcite.avatica.proto.Common.ColumnMetaDataOrBuilder> 
           getColumnsOrBuilderList() {
        if (columnsBuilder_ != null) {
          return columnsBuilder_.getMessageOrBuilderList();
        } else {
          return java.util.Collections.unmodifiableList(columns_);
        }
      }
      /**
       * <pre>
       * Only present when name = STRUCT
       * </pre>
       *
       * <code>repeated .ColumnMetaData columns = 4;</code>
       */
      public org.apache.calcite.avatica.proto.Common.ColumnMetaData.Builder addColumnsBuilder() {
        return getColumnsFieldBuilder().addBuilder(
            org.apache.calcite.avatica.proto.Common.ColumnMetaData.getDefaultInstance());
      }
      /**
       * <pre>
       * Only present when name = STRUCT
       * </pre>
       *
       * <code>repeated .ColumnMetaData columns = 4;</code>
       */
      public org.apache.calcite.avatica.proto.Common.ColumnMetaData.Builder addColumnsBuilder(
          int index) {
        return getColumnsFieldBuilder().addBuilder(
            index, org.apache.calcite.avatica.proto.Common.ColumnMetaData.getDefaultInstance());
      }
      /**
       * <pre>
       * Only present when name = STRUCT
       * </pre>
       *
       * <code>repeated .ColumnMetaData columns = 4;</code>
       */
      public java.util.List<org.apache.calcite.avatica.proto.Common.ColumnMetaData.Builder> 
           getColumnsBuilderList() {
        return getColumnsFieldBuilder().getBuilderList();
      }
      private com.google.protobuf.RepeatedFieldBuilderV3<
          org.apache.calcite.avatica.proto.Common.ColumnMetaData, org.apache.calcite.avatica.proto.Common.ColumnMetaData.Builder, org.apache.calcite.avatica.proto.Common.ColumnMetaDataOrBuilder> 
          getColumnsFieldBuilder() {
        if (columnsBuilder_ == null) {
          columnsBuilder_ = new com.google.protobuf.RepeatedFieldBuilderV3<
              org.apache.calcite.avatica.proto.Common.ColumnMetaData, org.apache.calcite.avatica.proto.Common.ColumnMetaData.Builder, org.apache.calcite.avatica.proto.Common.ColumnMetaDataOrBuilder>(
                  columns_,
                  ((bitField0_ & 0x00000001) != 0),
                  getParentForChildren(),
                  isClean());
          columns_ = null;
        }
        return columnsBuilder_;
      }

      private org.apache.calcite.avatica.proto.Common.AvaticaType component_;
      private com.google.protobuf.SingleFieldBuilderV3<
          org.apache.calcite.avatica.proto.Common.AvaticaType, org.apache.calcite.avatica.proto.Common.AvaticaType.Builder, org.apache.calcite.avatica.proto.Common.AvaticaTypeOrBuilder> componentBuilder_;
      /**
       * <pre>
       * Only present when name = ARRAY
       * </pre>
       *
       * <code>.AvaticaType component = 5;</code>
       * @return Whether the component field is set.
       */
      public boolean hasComponent() {
        return componentBuilder_ != null || component_ != null;
      }
      /**
       * <pre>
       * Only present when name = ARRAY
       * </pre>
       *
       * <code>.AvaticaType component = 5;</code>
       * @return The component.
       */
      public org.apache.calcite.avatica.proto.Common.AvaticaType getComponent() {
        if (componentBuilder_ == null) {
          return component_ == null ? org.apache.calcite.avatica.proto.Common.AvaticaType.getDefaultInstance() : component_;
        } else {
          return componentBuilder_.getMessage();
        }
      }
      /**
       * <pre>
       * Only present when name = ARRAY
       * </pre>
       *
       * <code>.AvaticaType component = 5;</code>
       */
      public Builder setComponent(org.apache.calcite.avatica.proto.Common.AvaticaType value) {
        if (componentBuilder_ == null) {
          if (value == null) {
            throw new NullPointerException();
          }
          component_ = value;
          onChanged();
        } else {
          componentBuilder_.setMessage(value);
        }

        return this;
      }
      /**
       * <pre>
       * Only present when name = ARRAY
       * </pre>
       *
       * <code>.AvaticaType component = 5;</code>
       */
      public Builder setComponent(
          org.apache.calcite.avatica.proto.Common.AvaticaType.Builder builderForValue) {
        if (componentBuilder_ == null) {
          component_ = builderForValue.build();
          onChanged();
        } else {
          componentBuilder_.setMessage(builderForValue.build());
        }

        return this;
      }
      /**
       * <pre>
       * Only present when name = ARRAY
       * </pre>
       *
       * <code>.AvaticaType component = 5;</code>
       */
      public Builder mergeComponent(org.apache.calcite.avatica.proto.Common.AvaticaType value) {
        if (componentBuilder_ == null) {
          if (component_ != null) {
            component_ =
              org.apache.calcite.avatica.proto.Common.AvaticaType.newBuilder(component_).mergeFrom(value).buildPartial();
          } else {
            component_ = value;
          }
          onChanged();
        } else {
          componentBuilder_.mergeFrom(value);
        }

        return this;
      }
      /**
       * <pre>
       * Only present when name = ARRAY
       * </pre>
       *
       * <code>.AvaticaType component = 5;</code>
       */
      public Builder clearComponent() {
        if (componentBuilder_ == null) {
          component_ = null;
          onChanged();
        } else {
          component_ = null;
          componentBuilder_ = null;
        }

        return this;
      }
      /**
       * <pre>
       * Only present when name = ARRAY
       * </pre>
       *
       * <code>.AvaticaType component = 5;</code>
       */
      public org.apache.calcite.avatica.proto.Common.AvaticaType.Builder getComponentBuilder() {
        
        onChanged();
        return getComponentFieldBuilder().getBuilder();
      }
      /**
       * <pre>
       * Only present when name = ARRAY
       * </pre>
       *
       * <code>.AvaticaType component = 5;</code>
       */
      public org.apache.calcite.avatica.proto.Common.AvaticaTypeOrBuilder getComponentOrBuilder() {
        if (componentBuilder_ != null) {
          return componentBuilder_.getMessageOrBuilder();
        } else {
          return component_ == null ?
              org.apache.calcite.avatica.proto.Common.AvaticaType.getDefaultInstance() : component_;
        }
      }
      /**
       * <pre>
       * Only present when name = ARRAY
       * </pre>
       *
       * <code>.AvaticaType component = 5;</code>
       */
      private com.google.protobuf.SingleFieldBuilderV3<
          org.apache.calcite.avatica.proto.Common.AvaticaType, org.apache.calcite.avatica.proto.Common.AvaticaType.Builder, org.apache.calcite.avatica.proto.Common.AvaticaTypeOrBuilder> 
          getComponentFieldBuilder() {
        if (componentBuilder_ == null) {
          componentBuilder_ = new com.google.protobuf.SingleFieldBuilderV3<
              org.apache.calcite.avatica.proto.Common.AvaticaType, org.apache.calcite.avatica.proto.Common.AvaticaType.Builder, org.apache.calcite.avatica.proto.Common.AvaticaTypeOrBuilder>(
                  getComponent(),
                  getParentForChildren(),
                  isClean());
          component_ = null;
        }
        return componentBuilder_;
      }
      @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:AvaticaType)
    }

    // @@protoc_insertion_point(class_scope:AvaticaType)
    private static final org.apache.calcite.avatica.proto.Common.AvaticaType DEFAULT_INSTANCE;
    static {
      DEFAULT_INSTANCE = new org.apache.calcite.avatica.proto.Common.AvaticaType();
    }

    public static org.apache.calcite.avatica.proto.Common.AvaticaType getDefaultInstance() {
      return DEFAULT_INSTANCE;
    }

    private static final com.google.protobuf.Parser<AvaticaType>
        PARSER = new com.google.protobuf.AbstractParser<AvaticaType>() {
      @java.lang.Override
      public AvaticaType 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<AvaticaType> parser() {
      return PARSER;
    }

    @java.lang.Override
    public com.google.protobuf.Parser<AvaticaType> getParserForType() {
      return PARSER;
    }

    @java.lang.Override
    public org.apache.calcite.avatica.proto.Common.AvaticaType getDefaultInstanceForType() {
      return DEFAULT_INSTANCE;
    }

  }

  public interface AvaticaParameterOrBuilder extends
      // @@protoc_insertion_point(interface_extends:AvaticaParameter)
      com.google.protobuf.MessageOrBuilder {

    /**
     * <code>bool signed = 1;</code>
     * @return The signed.
     */
    boolean getSigned();

    /**
     * <code>uint32 precision = 2;</code>
     * @return The precision.
     */
    int getPrecision();

    /**
     * <code>uint32 scale = 3;</code>
     * @return The scale.
     */
    int getScale();

    /**
     * <code>uint32 parameter_type = 4;</code>
     * @return The parameterType.
     */
    int getParameterType();

    /**
     * <code>string type_name = 5;</code>
     * @return The typeName.
     */
    java.lang.String getTypeName();
    /**
     * <code>string type_name = 5;</code>
     * @return The bytes for typeName.
     */
    com.google.protobuf.ByteString
        getTypeNameBytes();

    /**
     * <code>string class_name = 6;</code>
     * @return The className.
     */
    java.lang.String getClassName();
    /**
     * <code>string class_name = 6;</code>
     * @return The bytes for className.
     */
    com.google.protobuf.ByteString
        getClassNameBytes();

    /**
     * <code>string name = 7;</code>
     * @return The name.
     */
    java.lang.String getName();
    /**
     * <code>string name = 7;</code>
     * @return The bytes for name.
     */
    com.google.protobuf.ByteString
        getNameBytes();
  }
  /**
   * <pre>
   * Metadata for a parameter
   * </pre>
   *
   * Protobuf type {@code AvaticaParameter}
   */
  public static final class AvaticaParameter extends
      com.google.protobuf.GeneratedMessageV3 implements
      // @@protoc_insertion_point(message_implements:AvaticaParameter)
      AvaticaParameterOrBuilder {
  private static final long serialVersionUID = 0L;
    // Use AvaticaParameter.newBuilder() to construct.
    private AvaticaParameter(com.google.protobuf.GeneratedMessageV3.Builder<?> builder) {
      super(builder);
    }
    private AvaticaParameter() {
      typeName_ = "";
      className_ = "";
      name_ = "";
    }

    @java.lang.Override
    @SuppressWarnings({"unused"})
    protected java.lang.Object newInstance(
        UnusedPrivateParameter unused) {
      return new AvaticaParameter();
    }

    @java.lang.Override
    public final com.google.protobuf.UnknownFieldSet
    getUnknownFields() {
      return this.unknownFields;
    }
    public static final com.google.protobuf.Descriptors.Descriptor
        getDescriptor() {
      return org.apache.calcite.avatica.proto.Common.internal_static_AvaticaParameter_descriptor;
    }

    @java.lang.Override
    protected com.google.protobuf.GeneratedMessageV3.FieldAccessorTable
        internalGetFieldAccessorTable() {
      return org.apache.calcite.avatica.proto.Common.internal_static_AvaticaParameter_fieldAccessorTable
          .ensureFieldAccessorsInitialized(
              org.apache.calcite.avatica.proto.Common.AvaticaParameter.class, org.apache.calcite.avatica.proto.Common.AvaticaParameter.Builder.class);
    }

    public static final int SIGNED_FIELD_NUMBER = 1;
    private boolean signed_;
    /**
     * <code>bool signed = 1;</code>
     * @return The signed.
     */
    @java.lang.Override
    public boolean getSigned() {
      return signed_;
    }

    public static final int PRECISION_FIELD_NUMBER = 2;
    private int precision_;
    /**
     * <code>uint32 precision = 2;</code>
     * @return The precision.
     */
    @java.lang.Override
    public int getPrecision() {
      return precision_;
    }

    public static final int SCALE_FIELD_NUMBER = 3;
    private int scale_;
    /**
     * <code>uint32 scale = 3;</code>
     * @return The scale.
     */
    @java.lang.Override
    public int getScale() {
      return scale_;
    }

    public static final int PARAMETER_TYPE_FIELD_NUMBER = 4;
    private int parameterType_;
    /**
     * <code>uint32 parameter_type = 4;</code>
     * @return The parameterType.
     */
    @java.lang.Override
    public int getParameterType() {
      return parameterType_;
    }

    public static final int TYPE_NAME_FIELD_NUMBER = 5;
    private volatile java.lang.Object typeName_;
    /**
     * <code>string type_name = 5;</code>
     * @return The typeName.
     */
    @java.lang.Override
    public java.lang.String getTypeName() {
      java.lang.Object ref = typeName_;
      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();
        typeName_ = s;
        return s;
      }
    }
    /**
     * <code>string type_name = 5;</code>
     * @return The bytes for typeName.
     */
    @java.lang.Override
    public com.google.protobuf.ByteString
        getTypeNameBytes() {
      java.lang.Object ref = typeName_;
      if (ref instanceof java.lang.String) {
        com.google.protobuf.ByteString b = 
            com.google.protobuf.ByteString.copyFromUtf8(
                (java.lang.String) ref);
        typeName_ = b;
        return b;
      } else {
        return (com.google.protobuf.ByteString) ref;
      }
    }

    public static final int CLASS_NAME_FIELD_NUMBER = 6;
    private volatile java.lang.Object className_;
    /**
     * <code>string class_name = 6;</code>
     * @return The className.
     */
    @java.lang.Override
    public java.lang.String getClassName() {
      java.lang.Object ref = className_;
      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();
        className_ = s;
        return s;
      }
    }
    /**
     * <code>string class_name = 6;</code>
     * @return The bytes for className.
     */
    @java.lang.Override
    public com.google.protobuf.ByteString
        getClassNameBytes() {
      java.lang.Object ref = className_;
      if (ref instanceof java.lang.String) {
        com.google.protobuf.ByteString b = 
            com.google.protobuf.ByteString.copyFromUtf8(
                (java.lang.String) ref);
        className_ = b;
        return b;
      } else {
        return (com.google.protobuf.ByteString) ref;
      }
    }

    public static final int NAME_FIELD_NUMBER = 7;
    private volatile java.lang.Object name_;
    /**
     * <code>string name = 7;</code>
     * @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();
        name_ = s;
        return s;
      }
    }
    /**
     * <code>string name = 7;</code>
     * @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;
      }
    }

    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 (signed_ != false) {
        output.writeBool(1, signed_);
      }
      if (precision_ != 0) {
        output.writeUInt32(2, precision_);
      }
      if (scale_ != 0) {
        output.writeUInt32(3, scale_);
      }
      if (parameterType_ != 0) {
        output.writeUInt32(4, parameterType_);
      }
      if (!com.google.protobuf.GeneratedMessageV3.isStringEmpty(typeName_)) {
        com.google.protobuf.GeneratedMessageV3.writeString(output, 5, typeName_);
      }
      if (!com.google.protobuf.GeneratedMessageV3.isStringEmpty(className_)) {
        com.google.protobuf.GeneratedMessageV3.writeString(output, 6, className_);
      }
      if (!com.google.protobuf.GeneratedMessageV3.isStringEmpty(name_)) {
        com.google.protobuf.GeneratedMessageV3.writeString(output, 7, name_);
      }
      getUnknownFields().writeTo(output);
    }

    @java.lang.Override
    public int getSerializedSize() {
      int size = memoizedSize;
      if (size != -1) return size;

      size = 0;
      if (signed_ != false) {
        size += com.google.protobuf.CodedOutputStream
          .computeBoolSize(1, signed_);
      }
      if (precision_ != 0) {
        size += com.google.protobuf.CodedOutputStream
          .computeUInt32Size(2, precision_);
      }
      if (scale_ != 0) {
        size += com.google.protobuf.CodedOutputStream
          .computeUInt32Size(3, scale_);
      }
      if (parameterType_ != 0) {
        size += com.google.protobuf.CodedOutputStream
          .computeUInt32Size(4, parameterType_);
      }
      if (!com.google.protobuf.GeneratedMessageV3.isStringEmpty(typeName_)) {
        size += com.google.protobuf.GeneratedMessageV3.computeStringSize(5, typeName_);
      }
      if (!com.google.protobuf.GeneratedMessageV3.isStringEmpty(className_)) {
        size += com.google.protobuf.GeneratedMessageV3.computeStringSize(6, className_);
      }
      if (!com.google.protobuf.GeneratedMessageV3.isStringEmpty(name_)) {
        size += com.google.protobuf.GeneratedMessageV3.computeStringSize(7, name_);
      }
      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 org.apache.calcite.avatica.proto.Common.AvaticaParameter)) {
        return super.equals(obj);
      }
      org.apache.calcite.avatica.proto.Common.AvaticaParameter other = (org.apache.calcite.avatica.proto.Common.AvaticaParameter) obj;

      if (getSigned()
          != other.getSigned()) return false;
      if (getPrecision()
          != other.getPrecision()) return false;
      if (getScale()
          != other.getScale()) return false;
      if (getParameterType()
          != other.getParameterType()) return false;
      if (!getTypeName()
          .equals(other.getTypeName())) return false;
      if (!getClassName()
          .equals(other.getClassName())) return false;
      if (!getName()
          .equals(other.getName())) 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();
      hash = (37 * hash) + SIGNED_FIELD_NUMBER;
      hash = (53 * hash) + com.google.protobuf.Internal.hashBoolean(
          getSigned());
      hash = (37 * hash) + PRECISION_FIELD_NUMBER;
      hash = (53 * hash) + getPrecision();
      hash = (37 * hash) + SCALE_FIELD_NUMBER;
      hash = (53 * hash) + getScale();
      hash = (37 * hash) + PARAMETER_TYPE_FIELD_NUMBER;
      hash = (53 * hash) + getParameterType();
      hash = (37 * hash) + TYPE_NAME_FIELD_NUMBER;
      hash = (53 * hash) + getTypeName().hashCode();
      hash = (37 * hash) + CLASS_NAME_FIELD_NUMBER;
      hash = (53 * hash) + getClassName().hashCode();
      hash = (37 * hash) + NAME_FIELD_NUMBER;
      hash = (53 * hash) + getName().hashCode();
      hash = (29 * hash) + getUnknownFields().hashCode();
      memoizedHashCode = hash;
      return hash;
    }

    public static org.apache.calcite.avatica.proto.Common.AvaticaParameter parseFrom(
        java.nio.ByteBuffer data)
        throws com.google.protobuf.InvalidProtocolBufferException {
      return PARSER.parseFrom(data);
    }
    public static org.apache.calcite.avatica.proto.Common.AvaticaParameter parseFrom(
        java.nio.ByteBuffer data,
        com.google.protobuf.ExtensionRegistryLite extensionRegistry)
        throws com.google.protobuf.InvalidProtocolBufferException {
      return PARSER.parseFrom(data, extensionRegistry);
    }
    public static org.apache.calcite.avatica.proto.Common.AvaticaParameter parseFrom(
        com.google.protobuf.ByteString data)
        throws com.google.protobuf.InvalidProtocolBufferException {
      return PARSER.parseFrom(data);
    }
    public static org.apache.calcite.avatica.proto.Common.AvaticaParameter parseFrom(
        com.google.protobuf.ByteString data,
        com.google.protobuf.ExtensionRegistryLite extensionRegistry)
        throws com.google.protobuf.InvalidProtocolBufferException {
      return PARSER.parseFrom(data, extensionRegistry);
    }
    public static org.apache.calcite.avatica.proto.Common.AvaticaParameter parseFrom(byte[] data)
        throws com.google.protobuf.InvalidProtocolBufferException {
      return PARSER.parseFrom(data);
    }
    public static org.apache.calcite.avatica.proto.Common.AvaticaParameter parseFrom(
        byte[] data,
        com.google.protobuf.ExtensionRegistryLite extensionRegistry)
        throws com.google.protobuf.InvalidProtocolBufferException {
      return PARSER.parseFrom(data, extensionRegistry);
    }
    public static org.apache.calcite.avatica.proto.Common.AvaticaParameter parseFrom(java.io.InputStream input)
        throws java.io.IOException {
      return com.google.protobuf.GeneratedMessageV3
          .parseWithIOException(PARSER, input);
    }
    public static org.apache.calcite.avatica.proto.Common.AvaticaParameter 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 org.apache.calcite.avatica.proto.Common.AvaticaParameter parseDelimitedFrom(java.io.InputStream input)
        throws java.io.IOException {
      return com.google.protobuf.GeneratedMessageV3
          .parseDelimitedWithIOException(PARSER, input);
    }
    public static org.apache.calcite.avatica.proto.Common.AvaticaParameter 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 org.apache.calcite.avatica.proto.Common.AvaticaParameter parseFrom(
        com.google.protobuf.CodedInputStream input)
        throws java.io.IOException {
      return com.google.protobuf.GeneratedMessageV3
          .parseWithIOException(PARSER, input);
    }
    public static org.apache.calcite.avatica.proto.Common.AvaticaParameter 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(org.apache.calcite.avatica.proto.Common.AvaticaParameter 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;
    }
    /**
     * <pre>
     * Metadata for a parameter
     * </pre>
     *
     * Protobuf type {@code AvaticaParameter}
     */
    public static final class Builder extends
        com.google.protobuf.GeneratedMessageV3.Builder<Builder> implements
        // @@protoc_insertion_point(builder_implements:AvaticaParameter)
        org.apache.calcite.avatica.proto.Common.AvaticaParameterOrBuilder {
      public static final com.google.protobuf.Descriptors.Descriptor
          getDescriptor() {
        return org.apache.calcite.avatica.proto.Common.internal_static_AvaticaParameter_descriptor;
      }

      @java.lang.Override
      protected com.google.protobuf.GeneratedMessageV3.FieldAccessorTable
          internalGetFieldAccessorTable() {
        return org.apache.calcite.avatica.proto.Common.internal_static_AvaticaParameter_fieldAccessorTable
            .ensureFieldAccessorsInitialized(
                org.apache.calcite.avatica.proto.Common.AvaticaParameter.class, org.apache.calcite.avatica.proto.Common.AvaticaParameter.Builder.class);
      }

      // Construct using org.apache.calcite.avatica.proto.Common.AvaticaParameter.newBuilder()
      private Builder() {

      }

      private Builder(
          com.google.protobuf.GeneratedMessageV3.BuilderParent parent) {
        super(parent);

      }
      @java.lang.Override
      public Builder clear() {
        super.clear();
        signed_ = false;

        precision_ = 0;

        scale_ = 0;

        parameterType_ = 0;

        typeName_ = "";

        className_ = "";

        name_ = "";

        return this;
      }

      @java.lang.Override
      public com.google.protobuf.Descriptors.Descriptor
          getDescriptorForType() {
        return org.apache.calcite.avatica.proto.Common.internal_static_AvaticaParameter_descriptor;
      }

      @java.lang.Override
      public org.apache.calcite.avatica.proto.Common.AvaticaParameter getDefaultInstanceForType() {
        return org.apache.calcite.avatica.proto.Common.AvaticaParameter.getDefaultInstance();
      }

      @java.lang.Override
      public org.apache.calcite.avatica.proto.Common.AvaticaParameter build() {
        org.apache.calcite.avatica.proto.Common.AvaticaParameter result = buildPartial();
        if (!result.isInitialized()) {
          throw newUninitializedMessageException(result);
        }
        return result;
      }

      @java.lang.Override
      public org.apache.calcite.avatica.proto.Common.AvaticaParameter buildPartial() {
        org.apache.calcite.avatica.proto.Common.AvaticaParameter result = new org.apache.calcite.avatica.proto.Common.AvaticaParameter(this);
        result.signed_ = signed_;
        result.precision_ = precision_;
        result.scale_ = scale_;
        result.parameterType_ = parameterType_;
        result.typeName_ = typeName_;
        result.className_ = className_;
        result.name_ = name_;
        onBuilt();
        return result;
      }

      @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 org.apache.calcite.avatica.proto.Common.AvaticaParameter) {
          return mergeFrom((org.apache.calcite.avatica.proto.Common.AvaticaParameter)other);
        } else {
          super.mergeFrom(other);
          return this;
        }
      }

      public Builder mergeFrom(org.apache.calcite.avatica.proto.Common.AvaticaParameter other) {
        if (other == org.apache.calcite.avatica.proto.Common.AvaticaParameter.getDefaultInstance()) return this;
        if (other.getSigned() != false) {
          setSigned(other.getSigned());
        }
        if (other.getPrecision() != 0) {
          setPrecision(other.getPrecision());
        }
        if (other.getScale() != 0) {
          setScale(other.getScale());
        }
        if (other.getParameterType() != 0) {
          setParameterType(other.getParameterType());
        }
        if (!other.getTypeName().isEmpty()) {
          typeName_ = other.typeName_;
          onChanged();
        }
        if (!other.getClassName().isEmpty()) {
          className_ = other.className_;
          onChanged();
        }
        if (!other.getName().isEmpty()) {
          name_ = other.name_;
          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: {
                signed_ = input.readBool();

                break;
              } // case 8
              case 16: {
                precision_ = input.readUInt32();

                break;
              } // case 16
              case 24: {
                scale_ = input.readUInt32();

                break;
              } // case 24
              case 32: {
                parameterType_ = input.readUInt32();

                break;
              } // case 32
              case 42: {
                typeName_ = input.readStringRequireUtf8();

                break;
              } // case 42
              case 50: {
                className_ = input.readStringRequireUtf8();

                break;
              } // case 50
              case 58: {
                name_ = input.readStringRequireUtf8();

                break;
              } // case 58
              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 boolean signed_ ;
      /**
       * <code>bool signed = 1;</code>
       * @return The signed.
       */
      @java.lang.Override
      public boolean getSigned() {
        return signed_;
      }
      /**
       * <code>bool signed = 1;</code>
       * @param value The signed to set.
       * @return This builder for chaining.
       */
      public Builder setSigned(boolean value) {
        
        signed_ = value;
        onChanged();
        return this;
      }
      /**
       * <code>bool signed = 1;</code>
       * @return This builder for chaining.
       */
      public Builder clearSigned() {
        
        signed_ = false;
        onChanged();
        return this;
      }

      private int precision_ ;
      /**
       * <code>uint32 precision = 2;</code>
       * @return The precision.
       */
      @java.lang.Override
      public int getPrecision() {
        return precision_;
      }
      /**
       * <code>uint32 precision = 2;</code>
       * @param value The precision to set.
       * @return This builder for chaining.
       */
      public Builder setPrecision(int value) {
        
        precision_ = value;
        onChanged();
        return this;
      }
      /**
       * <code>uint32 precision = 2;</code>
       * @return This builder for chaining.
       */
      public Builder clearPrecision() {
        
        precision_ = 0;
        onChanged();
        return this;
      }

      private int scale_ ;
      /**
       * <code>uint32 scale = 3;</code>
       * @return The scale.
       */
      @java.lang.Override
      public int getScale() {
        return scale_;
      }
      /**
       * <code>uint32 scale = 3;</code>
       * @param value The scale to set.
       * @return This builder for chaining.
       */
      public Builder setScale(int value) {
        
        scale_ = value;
        onChanged();
        return this;
      }
      /**
       * <code>uint32 scale = 3;</code>
       * @return This builder for chaining.
       */
      public Builder clearScale() {
        
        scale_ = 0;
        onChanged();
        return this;
      }

      private int parameterType_ ;
      /**
       * <code>uint32 parameter_type = 4;</code>
       * @return The parameterType.
       */
      @java.lang.Override
      public int getParameterType() {
        return parameterType_;
      }
      /**
       * <code>uint32 parameter_type = 4;</code>
       * @param value The parameterType to set.
       * @return This builder for chaining.
       */
      public Builder setParameterType(int value) {
        
        parameterType_ = value;
        onChanged();
        return this;
      }
      /**
       * <code>uint32 parameter_type = 4;</code>
       * @return This builder for chaining.
       */
      public Builder clearParameterType() {
        
        parameterType_ = 0;
        onChanged();
        return this;
      }

      private java.lang.Object typeName_ = "";
      /**
       * <code>string type_name = 5;</code>
       * @return The typeName.
       */
      public java.lang.String getTypeName() {
        java.lang.Object ref = typeName_;
        if (!(ref instanceof java.lang.String)) {
          com.google.protobuf.ByteString bs =
              (com.google.protobuf.ByteString) ref;
          java.lang.String s = bs.toStringUtf8();
          typeName_ = s;
          return s;
        } else {
          return (java.lang.String) ref;
        }
      }
      /**
       * <code>string type_name = 5;</code>
       * @return The bytes for typeName.
       */
      public com.google.protobuf.ByteString
          getTypeNameBytes() {
        java.lang.Object ref = typeName_;
        if (ref instanceof String) {
          com.google.protobuf.ByteString b = 
              com.google.protobuf.ByteString.copyFromUtf8(
                  (java.lang.String) ref);
          typeName_ = b;
          return b;
        } else {
          return (com.google.protobuf.ByteString) ref;
        }
      }
      /**
       * <code>string type_name = 5;</code>
       * @param value The typeName to set.
       * @return This builder for chaining.
       */
      public Builder setTypeName(
          java.lang.String value) {
        if (value == null) {
    throw new NullPointerException();
  }
  
        typeName_ = value;
        onChanged();
        return this;
      }
      /**
       * <code>string type_name = 5;</code>
       * @return This builder for chaining.
       */
      public Builder clearTypeName() {
        
        typeName_ = getDefaultInstance().getTypeName();
        onChanged();
        return this;
      }
      /**
       * <code>string type_name = 5;</code>
       * @param value The bytes for typeName to set.
       * @return This builder for chaining.
       */
      public Builder setTypeNameBytes(
          com.google.protobuf.ByteString value) {
        if (value == null) {
    throw new NullPointerException();
  }
  checkByteStringIsUtf8(value);
        
        typeName_ = value;
        onChanged();
        return this;
      }

      private java.lang.Object className_ = "";
      /**
       * <code>string class_name = 6;</code>
       * @return The className.
       */
      public java.lang.String getClassName() {
        java.lang.Object ref = className_;
        if (!(ref instanceof java.lang.String)) {
          com.google.protobuf.ByteString bs =
              (com.google.protobuf.ByteString) ref;
          java.lang.String s = bs.toStringUtf8();
          className_ = s;
          return s;
        } else {
          return (java.lang.String) ref;
        }
      }
      /**
       * <code>string class_name = 6;</code>
       * @return The bytes for className.
       */
      public com.google.protobuf.ByteString
          getClassNameBytes() {
        java.lang.Object ref = className_;
        if (ref instanceof String) {
          com.google.protobuf.ByteString b = 
              com.google.protobuf.ByteString.copyFromUtf8(
                  (java.lang.String) ref);
          className_ = b;
          return b;
        } else {
          return (com.google.protobuf.ByteString) ref;
        }
      }
      /**
       * <code>string class_name = 6;</code>
       * @param value The className to set.
       * @return This builder for chaining.
       */
      public Builder setClassName(
          java.lang.String value) {
        if (value == null) {
    throw new NullPointerException();
  }
  
        className_ = value;
        onChanged();
        return this;
      }
      /**
       * <code>string class_name = 6;</code>
       * @return This builder for chaining.
       */
      public Builder clearClassName() {
        
        className_ = getDefaultInstance().getClassName();
        onChanged();
        return this;
      }
      /**
       * <code>string class_name = 6;</code>
       * @param value The bytes for className to set.
       * @return This builder for chaining.
       */
      public Builder setClassNameBytes(
          com.google.protobuf.ByteString value) {
        if (value == null) {
    throw new NullPointerException();
  }
  checkByteStringIsUtf8(value);
        
        className_ = value;
        onChanged();
        return this;
      }

      private java.lang.Object name_ = "";
      /**
       * <code>string name = 7;</code>
       * @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();
          name_ = s;
          return s;
        } else {
          return (java.lang.String) ref;
        }
      }
      /**
       * <code>string name = 7;</code>
       * @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;
        }
      }
      /**
       * <code>string name = 7;</code>
       * @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;
        onChanged();
        return this;
      }
      /**
       * <code>string name = 7;</code>
       * @return This builder for chaining.
       */
      public Builder clearName() {
        
        name_ = getDefaultInstance().getName();
        onChanged();
        return this;
      }
      /**
       * <code>string name = 7;</code>
       * @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();
  }
  checkByteStringIsUtf8(value);
        
        name_ = value;
        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:AvaticaParameter)
    }

    // @@protoc_insertion_point(class_scope:AvaticaParameter)
    private static final org.apache.calcite.avatica.proto.Common.AvaticaParameter DEFAULT_INSTANCE;
    static {
      DEFAULT_INSTANCE = new org.apache.calcite.avatica.proto.Common.AvaticaParameter();
    }

    public static org.apache.calcite.avatica.proto.Common.AvaticaParameter getDefaultInstance() {
      return DEFAULT_INSTANCE;
    }

    private static final com.google.protobuf.Parser<AvaticaParameter>
        PARSER = new com.google.protobuf.AbstractParser<AvaticaParameter>() {
      @java.lang.Override
      public AvaticaParameter 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<AvaticaParameter> parser() {
      return PARSER;
    }

    @java.lang.Override
    public com.google.protobuf.Parser<AvaticaParameter> getParserForType() {
      return PARSER;
    }

    @java.lang.Override
    public org.apache.calcite.avatica.proto.Common.AvaticaParameter getDefaultInstanceForType() {
      return DEFAULT_INSTANCE;
    }

  }

  public interface CursorFactoryOrBuilder extends
      // @@protoc_insertion_point(interface_extends:CursorFactory)
      com.google.protobuf.MessageOrBuilder {

    /**
     * <code>.CursorFactory.Style style = 1;</code>
     * @return The enum numeric value on the wire for style.
     */
    int getStyleValue();
    /**
     * <code>.CursorFactory.Style style = 1;</code>
     * @return The style.
     */
    org.apache.calcite.avatica.proto.Common.CursorFactory.Style getStyle();

    /**
     * <code>string class_name = 2;</code>
     * @return The className.
     */
    java.lang.String getClassName();
    /**
     * <code>string class_name = 2;</code>
     * @return The bytes for className.
     */
    com.google.protobuf.ByteString
        getClassNameBytes();

    /**
     * <code>repeated string field_names = 3;</code>
     * @return A list containing the fieldNames.
     */
    java.util.List<java.lang.String>
        getFieldNamesList();
    /**
     * <code>repeated string field_names = 3;</code>
     * @return The count of fieldNames.
     */
    int getFieldNamesCount();
    /**
     * <code>repeated string field_names = 3;</code>
     * @param index The index of the element to return.
     * @return The fieldNames at the given index.
     */
    java.lang.String getFieldNames(int index);
    /**
     * <code>repeated string field_names = 3;</code>
     * @param index The index of the value to return.
     * @return The bytes of the fieldNames at the given index.
     */
    com.google.protobuf.ByteString
        getFieldNamesBytes(int index);
  }
  /**
   * <pre>
   * Information necessary to convert an Iterable into a Calcite Cursor
   * </pre>
   *
   * Protobuf type {@code CursorFactory}
   */
  public static final class CursorFactory extends
      com.google.protobuf.GeneratedMessageV3 implements
      // @@protoc_insertion_point(message_implements:CursorFactory)
      CursorFactoryOrBuilder {
  private static final long serialVersionUID = 0L;
    // Use CursorFactory.newBuilder() to construct.
    private CursorFactory(com.google.protobuf.GeneratedMessageV3.Builder<?> builder) {
      super(builder);
    }
    private CursorFactory() {
      style_ = 0;
      className_ = "";
      fieldNames_ = com.google.protobuf.LazyStringArrayList.EMPTY;
    }

    @java.lang.Override
    @SuppressWarnings({"unused"})
    protected java.lang.Object newInstance(
        UnusedPrivateParameter unused) {
      return new CursorFactory();
    }

    @java.lang.Override
    public final com.google.protobuf.UnknownFieldSet
    getUnknownFields() {
      return this.unknownFields;
    }
    public static final com.google.protobuf.Descriptors.Descriptor
        getDescriptor() {
      return org.apache.calcite.avatica.proto.Common.internal_static_CursorFactory_descriptor;
    }

    @java.lang.Override
    protected com.google.protobuf.GeneratedMessageV3.FieldAccessorTable
        internalGetFieldAccessorTable() {
      return org.apache.calcite.avatica.proto.Common.internal_static_CursorFactory_fieldAccessorTable
          .ensureFieldAccessorsInitialized(
              org.apache.calcite.avatica.proto.Common.CursorFactory.class, org.apache.calcite.avatica.proto.Common.CursorFactory.Builder.class);
    }

    /**
     * Protobuf enum {@code CursorFactory.Style}
     */
    public enum Style
        implements com.google.protobuf.ProtocolMessageEnum {
      /**
       * <code>OBJECT = 0;</code>
       */
      OBJECT(0),
      /**
       * <code>RECORD = 1;</code>
       */
      RECORD(1),
      /**
       * <code>RECORD_PROJECTION = 2;</code>
       */
      RECORD_PROJECTION(2),
      /**
       * <code>ARRAY = 3;</code>
       */
      ARRAY(3),
      /**
       * <code>LIST = 4;</code>
       */
      LIST(4),
      /**
       * <code>MAP = 5;</code>
       */
      MAP(5),
      UNRECOGNIZED(-1),
      ;

      /**
       * <code>OBJECT = 0;</code>
       */
      public static final int OBJECT_VALUE = 0;
      /**
       * <code>RECORD = 1;</code>
       */
      public static final int RECORD_VALUE = 1;
      /**
       * <code>RECORD_PROJECTION = 2;</code>
       */
      public static final int RECORD_PROJECTION_VALUE = 2;
      /**
       * <code>ARRAY = 3;</code>
       */
      public static final int ARRAY_VALUE = 3;
      /**
       * <code>LIST = 4;</code>
       */
      public static final int LIST_VALUE = 4;
      /**
       * <code>MAP = 5;</code>
       */
      public static final int MAP_VALUE = 5;


      public final int getNumber() {
        if (this == UNRECOGNIZED) {
          throw new java.lang.IllegalArgumentException(
              "Can't get the number of an unknown enum value.");
        }
        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 Style 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 Style forNumber(int value) {
        switch (value) {
          case 0: return OBJECT;
          case 1: return RECORD;
          case 2: return RECORD_PROJECTION;
          case 3: return ARRAY;
          case 4: return LIST;
          case 5: return MAP;
          default: return null;
        }
      }

      public static com.google.protobuf.Internal.EnumLiteMap<Style>
          internalGetValueMap() {
        return internalValueMap;
      }
      private static final com.google.protobuf.Internal.EnumLiteMap<
          Style> internalValueMap =
            new com.google.protobuf.Internal.EnumLiteMap<Style>() {
              public Style findValueByNumber(int number) {
                return Style.forNumber(number);
              }
            };

      public final com.google.protobuf.Descriptors.EnumValueDescriptor
          getValueDescriptor() {
        if (this == UNRECOGNIZED) {
          throw new java.lang.IllegalStateException(
              "Can't get the descriptor of an unrecognized enum value.");
        }
        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 org.apache.calcite.avatica.proto.Common.CursorFactory.getDescriptor().getEnumTypes().get(0);
      }

      private static final Style[] VALUES = values();

      public static Style valueOf(
          com.google.protobuf.Descriptors.EnumValueDescriptor desc) {
        if (desc.getType() != getDescriptor()) {
          throw new java.lang.IllegalArgumentException(
            "EnumValueDescriptor is not for this type.");
        }
        if (desc.getIndex() == -1) {
          return UNRECOGNIZED;
        }
        return VALUES[desc.getIndex()];
      }

      private final int value;

      private Style(int value) {
        this.value = value;
      }

      // @@protoc_insertion_point(enum_scope:CursorFactory.Style)
    }

    public static final int STYLE_FIELD_NUMBER = 1;
    private int style_;
    /**
     * <code>.CursorFactory.Style style = 1;</code>
     * @return The enum numeric value on the wire for style.
     */
    @java.lang.Override public int getStyleValue() {
      return style_;
    }
    /**
     * <code>.CursorFactory.Style style = 1;</code>
     * @return The style.
     */
    @java.lang.Override public org.apache.calcite.avatica.proto.Common.CursorFactory.Style getStyle() {
      @SuppressWarnings("deprecation")
      org.apache.calcite.avatica.proto.Common.CursorFactory.Style result = org.apache.calcite.avatica.proto.Common.CursorFactory.Style.valueOf(style_);
      return result == null ? org.apache.calcite.avatica.proto.Common.CursorFactory.Style.UNRECOGNIZED : result;
    }

    public static final int CLASS_NAME_FIELD_NUMBER = 2;
    private volatile java.lang.Object className_;
    /**
     * <code>string class_name = 2;</code>
     * @return The className.
     */
    @java.lang.Override
    public java.lang.String getClassName() {
      java.lang.Object ref = className_;
      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();
        className_ = s;
        return s;
      }
    }
    /**
     * <code>string class_name = 2;</code>
     * @return The bytes for className.
     */
    @java.lang.Override
    public com.google.protobuf.ByteString
        getClassNameBytes() {
      java.lang.Object ref = className_;
      if (ref instanceof java.lang.String) {
        com.google.protobuf.ByteString b = 
            com.google.protobuf.ByteString.copyFromUtf8(
                (java.lang.String) ref);
        className_ = b;
        return b;
      } else {
        return (com.google.protobuf.ByteString) ref;
      }
    }

    public static final int FIELD_NAMES_FIELD_NUMBER = 3;
    private com.google.protobuf.LazyStringList fieldNames_;
    /**
     * <code>repeated string field_names = 3;</code>
     * @return A list containing the fieldNames.
     */
    public com.google.protobuf.ProtocolStringList
        getFieldNamesList() {
      return fieldNames_;
    }
    /**
     * <code>repeated string field_names = 3;</code>
     * @return The count of fieldNames.
     */
    public int getFieldNamesCount() {
      return fieldNames_.size();
    }
    /**
     * <code>repeated string field_names = 3;</code>
     * @param index The index of the element to return.
     * @return The fieldNames at the given index.
     */
    public java.lang.String getFieldNames(int index) {
      return fieldNames_.get(index);
    }
    /**
     * <code>repeated string field_names = 3;</code>
     * @param index The index of the value to return.
     * @return The bytes of the fieldNames at the given index.
     */
    public com.google.protobuf.ByteString
        getFieldNamesBytes(int index) {
      return fieldNames_.getByteString(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 (style_ != org.apache.calcite.avatica.proto.Common.CursorFactory.Style.OBJECT.getNumber()) {
        output.writeEnum(1, style_);
      }
      if (!com.google.protobuf.GeneratedMessageV3.isStringEmpty(className_)) {
        com.google.protobuf.GeneratedMessageV3.writeString(output, 2, className_);
      }
      for (int i = 0; i < fieldNames_.size(); i++) {
        com.google.protobuf.GeneratedMessageV3.writeString(output, 3, fieldNames_.getRaw(i));
      }
      getUnknownFields().writeTo(output);
    }

    @java.lang.Override
    public int getSerializedSize() {
      int size = memoizedSize;
      if (size != -1) return size;

      size = 0;
      if (style_ != org.apache.calcite.avatica.proto.Common.CursorFactory.Style.OBJECT.getNumber()) {
        size += com.google.protobuf.CodedOutputStream
          .computeEnumSize(1, style_);
      }
      if (!com.google.protobuf.GeneratedMessageV3.isStringEmpty(className_)) {
        size += com.google.protobuf.GeneratedMessageV3.computeStringSize(2, className_);
      }
      {
        int dataSize = 0;
        for (int i = 0; i < fieldNames_.size(); i++) {
          dataSize += computeStringSizeNoTag(fieldNames_.getRaw(i));
        }
        size += dataSize;
        size += 1 * getFieldNamesList().size();
      }
      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 org.apache.calcite.avatica.proto.Common.CursorFactory)) {
        return super.equals(obj);
      }
      org.apache.calcite.avatica.proto.Common.CursorFactory other = (org.apache.calcite.avatica.proto.Common.CursorFactory) obj;

      if (style_ != other.style_) return false;
      if (!getClassName()
          .equals(other.getClassName())) return false;
      if (!getFieldNamesList()
          .equals(other.getFieldNamesList())) 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();
      hash = (37 * hash) + STYLE_FIELD_NUMBER;
      hash = (53 * hash) + style_;
      hash = (37 * hash) + CLASS_NAME_FIELD_NUMBER;
      hash = (53 * hash) + getClassName().hashCode();
      if (getFieldNamesCount() > 0) {
        hash = (37 * hash) + FIELD_NAMES_FIELD_NUMBER;
        hash = (53 * hash) + getFieldNamesList().hashCode();
      }
      hash = (29 * hash) + getUnknownFields().hashCode();
      memoizedHashCode = hash;
      return hash;
    }

    public static org.apache.calcite.avatica.proto.Common.CursorFactory parseFrom(
        java.nio.ByteBuffer data)
        throws com.google.protobuf.InvalidProtocolBufferException {
      return PARSER.parseFrom(data);
    }
    public static org.apache.calcite.avatica.proto.Common.CursorFactory parseFrom(
        java.nio.ByteBuffer data,
        com.google.protobuf.ExtensionRegistryLite extensionRegistry)
        throws com.google.protobuf.InvalidProtocolBufferException {
      return PARSER.parseFrom(data, extensionRegistry);
    }
    public static org.apache.calcite.avatica.proto.Common.CursorFactory parseFrom(
        com.google.protobuf.ByteString data)
        throws com.google.protobuf.InvalidProtocolBufferException {
      return PARSER.parseFrom(data);
    }
    public static org.apache.calcite.avatica.proto.Common.CursorFactory parseFrom(
        com.google.protobuf.ByteString data,
        com.google.protobuf.ExtensionRegistryLite extensionRegistry)
        throws com.google.protobuf.InvalidProtocolBufferException {
      return PARSER.parseFrom(data, extensionRegistry);
    }
    public static org.apache.calcite.avatica.proto.Common.CursorFactory parseFrom(byte[] data)
        throws com.google.protobuf.InvalidProtocolBufferException {
      return PARSER.parseFrom(data);
    }
    public static org.apache.calcite.avatica.proto.Common.CursorFactory parseFrom(
        byte[] data,
        com.google.protobuf.ExtensionRegistryLite extensionRegistry)
        throws com.google.protobuf.InvalidProtocolBufferException {
      return PARSER.parseFrom(data, extensionRegistry);
    }
    public static org.apache.calcite.avatica.proto.Common.CursorFactory parseFrom(java.io.InputStream input)
        throws java.io.IOException {
      return com.google.protobuf.GeneratedMessageV3
          .parseWithIOException(PARSER, input);
    }
    public static org.apache.calcite.avatica.proto.Common.CursorFactory 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 org.apache.calcite.avatica.proto.Common.CursorFactory parseDelimitedFrom(java.io.InputStream input)
        throws java.io.IOException {
      return com.google.protobuf.GeneratedMessageV3
          .parseDelimitedWithIOException(PARSER, input);
    }
    public static org.apache.calcite.avatica.proto.Common.CursorFactory 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 org.apache.calcite.avatica.proto.Common.CursorFactory parseFrom(
        com.google.protobuf.CodedInputStream input)
        throws java.io.IOException {
      return com.google.protobuf.GeneratedMessageV3
          .parseWithIOException(PARSER, input);
    }
    public static org.apache.calcite.avatica.proto.Common.CursorFactory 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(org.apache.calcite.avatica.proto.Common.CursorFactory 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;
    }
    /**
     * <pre>
     * Information necessary to convert an Iterable into a Calcite Cursor
     * </pre>
     *
     * Protobuf type {@code CursorFactory}
     */
    public static final class Builder extends
        com.google.protobuf.GeneratedMessageV3.Builder<Builder> implements
        // @@protoc_insertion_point(builder_implements:CursorFactory)
        org.apache.calcite.avatica.proto.Common.CursorFactoryOrBuilder {
      public static final com.google.protobuf.Descriptors.Descriptor
          getDescriptor() {
        return org.apache.calcite.avatica.proto.Common.internal_static_CursorFactory_descriptor;
      }

      @java.lang.Override
      protected com.google.protobuf.GeneratedMessageV3.FieldAccessorTable
          internalGetFieldAccessorTable() {
        return org.apache.calcite.avatica.proto.Common.internal_static_CursorFactory_fieldAccessorTable
            .ensureFieldAccessorsInitialized(
                org.apache.calcite.avatica.proto.Common.CursorFactory.class, org.apache.calcite.avatica.proto.Common.CursorFactory.Builder.class);
      }

      // Construct using org.apache.calcite.avatica.proto.Common.CursorFactory.newBuilder()
      private Builder() {

      }

      private Builder(
          com.google.protobuf.GeneratedMessageV3.BuilderParent parent) {
        super(parent);

      }
      @java.lang.Override
      public Builder clear() {
        super.clear();
        style_ = 0;

        className_ = "";

        fieldNames_ = com.google.protobuf.LazyStringArrayList.EMPTY;
        bitField0_ = (bitField0_ & ~0x00000001);
        return this;
      }

      @java.lang.Override
      public com.google.protobuf.Descriptors.Descriptor
          getDescriptorForType() {
        return org.apache.calcite.avatica.proto.Common.internal_static_CursorFactory_descriptor;
      }

      @java.lang.Override
      public org.apache.calcite.avatica.proto.Common.CursorFactory getDefaultInstanceForType() {
        return org.apache.calcite.avatica.proto.Common.CursorFactory.getDefaultInstance();
      }

      @java.lang.Override
      public org.apache.calcite.avatica.proto.Common.CursorFactory build() {
        org.apache.calcite.avatica.proto.Common.CursorFactory result = buildPartial();
        if (!result.isInitialized()) {
          throw newUninitializedMessageException(result);
        }
        return result;
      }

      @java.lang.Override
      public org.apache.calcite.avatica.proto.Common.CursorFactory buildPartial() {
        org.apache.calcite.avatica.proto.Common.CursorFactory result = new org.apache.calcite.avatica.proto.Common.CursorFactory(this);
        int from_bitField0_ = bitField0_;
        result.style_ = style_;
        result.className_ = className_;
        if (((bitField0_ & 0x00000001) != 0)) {
          fieldNames_ = fieldNames_.getUnmodifiableView();
          bitField0_ = (bitField0_ & ~0x00000001);
        }
        result.fieldNames_ = fieldNames_;
        onBuilt();
        return result;
      }

      @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 org.apache.calcite.avatica.proto.Common.CursorFactory) {
          return mergeFrom((org.apache.calcite.avatica.proto.Common.CursorFactory)other);
        } else {
          super.mergeFrom(other);
          return this;
        }
      }

      public Builder mergeFrom(org.apache.calcite.avatica.proto.Common.CursorFactory other) {
        if (other == org.apache.calcite.avatica.proto.Common.CursorFactory.getDefaultInstance()) return this;
        if (other.style_ != 0) {
          setStyleValue(other.getStyleValue());
        }
        if (!other.getClassName().isEmpty()) {
          className_ = other.className_;
          onChanged();
        }
        if (!other.fieldNames_.isEmpty()) {
          if (fieldNames_.isEmpty()) {
            fieldNames_ = other.fieldNames_;
            bitField0_ = (bitField0_ & ~0x00000001);
          } else {
            ensureFieldNamesIsMutable();
            fieldNames_.addAll(other.fieldNames_);
          }
          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: {
                style_ = input.readEnum();

                break;
              } // case 8
              case 18: {
                className_ = input.readStringRequireUtf8();

                break;
              } // case 18
              case 26: {
                java.lang.String s = input.readStringRequireUtf8();
                ensureFieldNamesIsMutable();
                fieldNames_.add(s);
                break;
              } // case 26
              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 style_ = 0;
      /**
       * <code>.CursorFactory.Style style = 1;</code>
       * @return The enum numeric value on the wire for style.
       */
      @java.lang.Override public int getStyleValue() {
        return style_;
      }
      /**
       * <code>.CursorFactory.Style style = 1;</code>
       * @param value The enum numeric value on the wire for style to set.
       * @return This builder for chaining.
       */
      public Builder setStyleValue(int value) {
        
        style_ = value;
        onChanged();
        return this;
      }
      /**
       * <code>.CursorFactory.Style style = 1;</code>
       * @return The style.
       */
      @java.lang.Override
      public org.apache.calcite.avatica.proto.Common.CursorFactory.Style getStyle() {
        @SuppressWarnings("deprecation")
        org.apache.calcite.avatica.proto.Common.CursorFactory.Style result = org.apache.calcite.avatica.proto.Common.CursorFactory.Style.valueOf(style_);
        return result == null ? org.apache.calcite.avatica.proto.Common.CursorFactory.Style.UNRECOGNIZED : result;
      }
      /**
       * <code>.CursorFactory.Style style = 1;</code>
       * @param value The style to set.
       * @return This builder for chaining.
       */
      public Builder setStyle(org.apache.calcite.avatica.proto.Common.CursorFactory.Style value) {
        if (value == null) {
          throw new NullPointerException();
        }
        
        style_ = value.getNumber();
        onChanged();
        return this;
      }
      /**
       * <code>.CursorFactory.Style style = 1;</code>
       * @return This builder for chaining.
       */
      public Builder clearStyle() {
        
        style_ = 0;
        onChanged();
        return this;
      }

      private java.lang.Object className_ = "";
      /**
       * <code>string class_name = 2;</code>
       * @return The className.
       */
      public java.lang.String getClassName() {
        java.lang.Object ref = className_;
        if (!(ref instanceof java.lang.String)) {
          com.google.protobuf.ByteString bs =
              (com.google.protobuf.ByteString) ref;
          java.lang.String s = bs.toStringUtf8();
          className_ = s;
          return s;
        } else {
          return (java.lang.String) ref;
        }
      }
      /**
       * <code>string class_name = 2;</code>
       * @return The bytes for className.
       */
      public com.google.protobuf.ByteString
          getClassNameBytes() {
        java.lang.Object ref = className_;
        if (ref instanceof String) {
          com.google.protobuf.ByteString b = 
              com.google.protobuf.ByteString.copyFromUtf8(
                  (java.lang.String) ref);
          className_ = b;
          return b;
        } else {
          return (com.google.protobuf.ByteString) ref;
        }
      }
      /**
       * <code>string class_name = 2;</code>
       * @param value The className to set.
       * @return This builder for chaining.
       */
      public Builder setClassName(
          java.lang.String value) {
        if (value == null) {
    throw new NullPointerException();
  }
  
        className_ = value;
        onChanged();
        return this;
      }
      /**
       * <code>string class_name = 2;</code>
       * @return This builder for chaining.
       */
      public Builder clearClassName() {
        
        className_ = getDefaultInstance().getClassName();
        onChanged();
        return this;
      }
      /**
       * <code>string class_name = 2;</code>
       * @param value The bytes for className to set.
       * @return This builder for chaining.
       */
      public Builder setClassNameBytes(
          com.google.protobuf.ByteString value) {
        if (value == null) {
    throw new NullPointerException();
  }
  checkByteStringIsUtf8(value);
        
        className_ = value;
        onChanged();
        return this;
      }

      private com.google.protobuf.LazyStringList fieldNames_ = com.google.protobuf.LazyStringArrayList.EMPTY;
      private void ensureFieldNamesIsMutable() {
        if (!((bitField0_ & 0x00000001) != 0)) {
          fieldNames_ = new com.google.protobuf.LazyStringArrayList(fieldNames_);
          bitField0_ |= 0x00000001;
         }
      }
      /**
       * <code>repeated string field_names = 3;</code>
       * @return A list containing the fieldNames.
       */
      public com.google.protobuf.ProtocolStringList
          getFieldNamesList() {
        return fieldNames_.getUnmodifiableView();
      }
      /**
       * <code>repeated string field_names = 3;</code>
       * @return The count of fieldNames.
       */
      public int getFieldNamesCount() {
        return fieldNames_.size();
      }
      /**
       * <code>repeated string field_names = 3;</code>
       * @param index The index of the element to return.
       * @return The fieldNames at the given index.
       */
      public java.lang.String getFieldNames(int index) {
        return fieldNames_.get(index);
      }
      /**
       * <code>repeated string field_names = 3;</code>
       * @param index The index of the value to return.
       * @return The bytes of the fieldNames at the given index.
       */
      public com.google.protobuf.ByteString
          getFieldNamesBytes(int index) {
        return fieldNames_.getByteString(index);
      }
      /**
       * <code>repeated string field_names = 3;</code>
       * @param index The index to set the value at.
       * @param value The fieldNames to set.
       * @return This builder for chaining.
       */
      public Builder setFieldNames(
          int index, java.lang.String value) {
        if (value == null) {
    throw new NullPointerException();
  }
  ensureFieldNamesIsMutable();
        fieldNames_.set(index, value);
        onChanged();
        return this;
      }
      /**
       * <code>repeated string field_names = 3;</code>
       * @param value The fieldNames to add.
       * @return This builder for chaining.
       */
      public Builder addFieldNames(
          java.lang.String value) {
        if (value == null) {
    throw new NullPointerException();
  }
  ensureFieldNamesIsMutable();
        fieldNames_.add(value);
        onChanged();
        return this;
      }
      /**
       * <code>repeated string field_names = 3;</code>
       * @param values The fieldNames to add.
       * @return This builder for chaining.
       */
      public Builder addAllFieldNames(
          java.lang.Iterable<java.lang.String> values) {
        ensureFieldNamesIsMutable();
        com.google.protobuf.AbstractMessageLite.Builder.addAll(
            values, fieldNames_);
        onChanged();
        return this;
      }
      /**
       * <code>repeated string field_names = 3;</code>
       * @return This builder for chaining.
       */
      public Builder clearFieldNames() {
        fieldNames_ = com.google.protobuf.LazyStringArrayList.EMPTY;
        bitField0_ = (bitField0_ & ~0x00000001);
        onChanged();
        return this;
      }
      /**
       * <code>repeated string field_names = 3;</code>
       * @param value The bytes of the fieldNames to add.
       * @return This builder for chaining.
       */
      public Builder addFieldNamesBytes(
          com.google.protobuf.ByteString value) {
        if (value == null) {
    throw new NullPointerException();
  }
  checkByteStringIsUtf8(value);
        ensureFieldNamesIsMutable();
        fieldNames_.add(value);
        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:CursorFactory)
    }

    // @@protoc_insertion_point(class_scope:CursorFactory)
    private static final org.apache.calcite.avatica.proto.Common.CursorFactory DEFAULT_INSTANCE;
    static {
      DEFAULT_INSTANCE = new org.apache.calcite.avatica.proto.Common.CursorFactory();
    }

    public static org.apache.calcite.avatica.proto.Common.CursorFactory getDefaultInstance() {
      return DEFAULT_INSTANCE;
    }

    private static final com.google.protobuf.Parser<CursorFactory>
        PARSER = new com.google.protobuf.AbstractParser<CursorFactory>() {
      @java.lang.Override
      public CursorFactory 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<CursorFactory> parser() {
      return PARSER;
    }

    @java.lang.Override
    public com.google.protobuf.Parser<CursorFactory> getParserForType() {
      return PARSER;
    }

    @java.lang.Override
    public org.apache.calcite.avatica.proto.Common.CursorFactory getDefaultInstanceForType() {
      return DEFAULT_INSTANCE;
    }

  }

  public interface FrameOrBuilder extends
      // @@protoc_insertion_point(interface_extends:Frame)
      com.google.protobuf.MessageOrBuilder {

    /**
     * <code>uint64 offset = 1;</code>
     * @return The offset.
     */
    long getOffset();

    /**
     * <code>bool done = 2;</code>
     * @return The done.
     */
    boolean getDone();

    /**
     * <code>repeated .Row rows = 3;</code>
     */
    java.util.List<org.apache.calcite.avatica.proto.Common.Row> 
        getRowsList();
    /**
     * <code>repeated .Row rows = 3;</code>
     */
    org.apache.calcite.avatica.proto.Common.Row getRows(int index);
    /**
     * <code>repeated .Row rows = 3;</code>
     */
    int getRowsCount();
    /**
     * <code>repeated .Row rows = 3;</code>
     */
    java.util.List<? extends org.apache.calcite.avatica.proto.Common.RowOrBuilder> 
        getRowsOrBuilderList();
    /**
     * <code>repeated .Row rows = 3;</code>
     */
    org.apache.calcite.avatica.proto.Common.RowOrBuilder getRowsOrBuilder(
        int index);
  }
  /**
   * <pre>
   * A collection of rows
   * </pre>
   *
   * Protobuf type {@code Frame}
   */
  public static final class Frame extends
      com.google.protobuf.GeneratedMessageV3 implements
      // @@protoc_insertion_point(message_implements:Frame)
      FrameOrBuilder {
  private static final long serialVersionUID = 0L;
    // Use Frame.newBuilder() to construct.
    private Frame(com.google.protobuf.GeneratedMessageV3.Builder<?> builder) {
      super(builder);
    }
    private Frame() {
      rows_ = java.util.Collections.emptyList();
    }

    @java.lang.Override
    @SuppressWarnings({"unused"})
    protected java.lang.Object newInstance(
        UnusedPrivateParameter unused) {
      return new Frame();
    }

    @java.lang.Override
    public final com.google.protobuf.UnknownFieldSet
    getUnknownFields() {
      return this.unknownFields;
    }
    public static final com.google.protobuf.Descriptors.Descriptor
        getDescriptor() {
      return org.apache.calcite.avatica.proto.Common.internal_static_Frame_descriptor;
    }

    @java.lang.Override
    protected com.google.protobuf.GeneratedMessageV3.FieldAccessorTable
        internalGetFieldAccessorTable() {
      return org.apache.calcite.avatica.proto.Common.internal_static_Frame_fieldAccessorTable
          .ensureFieldAccessorsInitialized(
              org.apache.calcite.avatica.proto.Common.Frame.class, org.apache.calcite.avatica.proto.Common.Frame.Builder.class);
    }

    public static final int OFFSET_FIELD_NUMBER = 1;
    private long offset_;
    /**
     * <code>uint64 offset = 1;</code>
     * @return The offset.
     */
    @java.lang.Override
    public long getOffset() {
      return offset_;
    }

    public static final int DONE_FIELD_NUMBER = 2;
    private boolean done_;
    /**
     * <code>bool done = 2;</code>
     * @return The done.
     */
    @java.lang.Override
    public boolean getDone() {
      return done_;
    }

    public static final int ROWS_FIELD_NUMBER = 3;
    private java.util.List<org.apache.calcite.avatica.proto.Common.Row> rows_;
    /**
     * <code>repeated .Row rows = 3;</code>
     */
    @java.lang.Override
    public java.util.List<org.apache.calcite.avatica.proto.Common.Row> getRowsList() {
      return rows_;
    }
    /**
     * <code>repeated .Row rows = 3;</code>
     */
    @java.lang.Override
    public java.util.List<? extends org.apache.calcite.avatica.proto.Common.RowOrBuilder> 
        getRowsOrBuilderList() {
      return rows_;
    }
    /**
     * <code>repeated .Row rows = 3;</code>
     */
    @java.lang.Override
    public int getRowsCount() {
      return rows_.size();
    }
    /**
     * <code>repeated .Row rows = 3;</code>
     */
    @java.lang.Override
    public org.apache.calcite.avatica.proto.Common.Row getRows(int index) {
      return rows_.get(index);
    }
    /**
     * <code>repeated .Row rows = 3;</code>
     */
    @java.lang.Override
    public org.apache.calcite.avatica.proto.Common.RowOrBuilder getRowsOrBuilder(
        int index) {
      return rows_.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 (offset_ != 0L) {
        output.writeUInt64(1, offset_);
      }
      if (done_ != false) {
        output.writeBool(2, done_);
      }
      for (int i = 0; i < rows_.size(); i++) {
        output.writeMessage(3, rows_.get(i));
      }
      getUnknownFields().writeTo(output);
    }

    @java.lang.Override
    public int getSerializedSize() {
      int size = memoizedSize;
      if (size != -1) return size;

      size = 0;
      if (offset_ != 0L) {
        size += com.google.protobuf.CodedOutputStream
          .computeUInt64Size(1, offset_);
      }
      if (done_ != false) {
        size += com.google.protobuf.CodedOutputStream
          .computeBoolSize(2, done_);
      }
      for (int i = 0; i < rows_.size(); i++) {
        size += com.google.protobuf.CodedOutputStream
          .computeMessageSize(3, rows_.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 org.apache.calcite.avatica.proto.Common.Frame)) {
        return super.equals(obj);
      }
      org.apache.calcite.avatica.proto.Common.Frame other = (org.apache.calcite.avatica.proto.Common.Frame) obj;

      if (getOffset()
          != other.getOffset()) return false;
      if (getDone()
          != other.getDone()) return false;
      if (!getRowsList()
          .equals(other.getRowsList())) 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();
      hash = (37 * hash) + OFFSET_FIELD_NUMBER;
      hash = (53 * hash) + com.google.protobuf.Internal.hashLong(
          getOffset());
      hash = (37 * hash) + DONE_FIELD_NUMBER;
      hash = (53 * hash) + com.google.protobuf.Internal.hashBoolean(
          getDone());
      if (getRowsCount() > 0) {
        hash = (37 * hash) + ROWS_FIELD_NUMBER;
        hash = (53 * hash) + getRowsList().hashCode();
      }
      hash = (29 * hash) + getUnknownFields().hashCode();
      memoizedHashCode = hash;
      return hash;
    }

    public static org.apache.calcite.avatica.proto.Common.Frame parseFrom(
        java.nio.ByteBuffer data)
        throws com.google.protobuf.InvalidProtocolBufferException {
      return PARSER.parseFrom(data);
    }
    public static org.apache.calcite.avatica.proto.Common.Frame parseFrom(
        java.nio.ByteBuffer data,
        com.google.protobuf.ExtensionRegistryLite extensionRegistry)
        throws com.google.protobuf.InvalidProtocolBufferException {
      return PARSER.parseFrom(data, extensionRegistry);
    }
    public static org.apache.calcite.avatica.proto.Common.Frame parseFrom(
        com.google.protobuf.ByteString data)
        throws com.google.protobuf.InvalidProtocolBufferException {
      return PARSER.parseFrom(data);
    }
    public static org.apache.calcite.avatica.proto.Common.Frame parseFrom(
        com.google.protobuf.ByteString data,
        com.google.protobuf.ExtensionRegistryLite extensionRegistry)
        throws com.google.protobuf.InvalidProtocolBufferException {
      return PARSER.parseFrom(data, extensionRegistry);
    }
    public static org.apache.calcite.avatica.proto.Common.Frame parseFrom(byte[] data)
        throws com.google.protobuf.InvalidProtocolBufferException {
      return PARSER.parseFrom(data);
    }
    public static org.apache.calcite.avatica.proto.Common.Frame parseFrom(
        byte[] data,
        com.google.protobuf.ExtensionRegistryLite extensionRegistry)
        throws com.google.protobuf.InvalidProtocolBufferException {
      return PARSER.parseFrom(data, extensionRegistry);
    }
    public static org.apache.calcite.avatica.proto.Common.Frame parseFrom(java.io.InputStream input)
        throws java.io.IOException {
      return com.google.protobuf.GeneratedMessageV3
          .parseWithIOException(PARSER, input);
    }
    public static org.apache.calcite.avatica.proto.Common.Frame 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 org.apache.calcite.avatica.proto.Common.Frame parseDelimitedFrom(java.io.InputStream input)
        throws java.io.IOException {
      return com.google.protobuf.GeneratedMessageV3
          .parseDelimitedWithIOException(PARSER, input);
    }
    public static org.apache.calcite.avatica.proto.Common.Frame 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 org.apache.calcite.avatica.proto.Common.Frame parseFrom(
        com.google.protobuf.CodedInputStream input)
        throws java.io.IOException {
      return com.google.protobuf.GeneratedMessageV3
          .parseWithIOException(PARSER, input);
    }
    public static org.apache.calcite.avatica.proto.Common.Frame 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(org.apache.calcite.avatica.proto.Common.Frame 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;
    }
    /**
     * <pre>
     * A collection of rows
     * </pre>
     *
     * Protobuf type {@code Frame}
     */
    public static final class Builder extends
        com.google.protobuf.GeneratedMessageV3.Builder<Builder> implements
        // @@protoc_insertion_point(builder_implements:Frame)
        org.apache.calcite.avatica.proto.Common.FrameOrBuilder {
      public static final com.google.protobuf.Descriptors.Descriptor
          getDescriptor() {
        return org.apache.calcite.avatica.proto.Common.internal_static_Frame_descriptor;
      }

      @java.lang.Override
      protected com.google.protobuf.GeneratedMessageV3.FieldAccessorTable
          internalGetFieldAccessorTable() {
        return org.apache.calcite.avatica.proto.Common.internal_static_Frame_fieldAccessorTable
            .ensureFieldAccessorsInitialized(
                org.apache.calcite.avatica.proto.Common.Frame.class, org.apache.calcite.avatica.proto.Common.Frame.Builder.class);
      }

      // Construct using org.apache.calcite.avatica.proto.Common.Frame.newBuilder()
      private Builder() {

      }

      private Builder(
          com.google.protobuf.GeneratedMessageV3.BuilderParent parent) {
        super(parent);

      }
      @java.lang.Override
      public Builder clear() {
        super.clear();
        offset_ = 0L;

        done_ = false;

        if (rowsBuilder_ == null) {
          rows_ = java.util.Collections.emptyList();
        } else {
          rows_ = null;
          rowsBuilder_.clear();
        }
        bitField0_ = (bitField0_ & ~0x00000001);
        return this;
      }

      @java.lang.Override
      public com.google.protobuf.Descriptors.Descriptor
          getDescriptorForType() {
        return org.apache.calcite.avatica.proto.Common.internal_static_Frame_descriptor;
      }

      @java.lang.Override
      public org.apache.calcite.avatica.proto.Common.Frame getDefaultInstanceForType() {
        return org.apache.calcite.avatica.proto.Common.Frame.getDefaultInstance();
      }

      @java.lang.Override
      public org.apache.calcite.avatica.proto.Common.Frame build() {
        org.apache.calcite.avatica.proto.Common.Frame result = buildPartial();
        if (!result.isInitialized()) {
          throw newUninitializedMessageException(result);
        }
        return result;
      }

      @java.lang.Override
      public org.apache.calcite.avatica.proto.Common.Frame buildPartial() {
        org.apache.calcite.avatica.proto.Common.Frame result = new org.apache.calcite.avatica.proto.Common.Frame(this);
        int from_bitField0_ = bitField0_;
        result.offset_ = offset_;
        result.done_ = done_;
        if (rowsBuilder_ == null) {
          if (((bitField0_ & 0x00000001) != 0)) {
            rows_ = java.util.Collections.unmodifiableList(rows_);
            bitField0_ = (bitField0_ & ~0x00000001);
          }
          result.rows_ = rows_;
        } else {
          result.rows_ = rowsBuilder_.build();
        }
        onBuilt();
        return result;
      }

      @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 org.apache.calcite.avatica.proto.Common.Frame) {
          return mergeFrom((org.apache.calcite.avatica.proto.Common.Frame)other);
        } else {
          super.mergeFrom(other);
          return this;
        }
      }

      public Builder mergeFrom(org.apache.calcite.avatica.proto.Common.Frame other) {
        if (other == org.apache.calcite.avatica.proto.Common.Frame.getDefaultInstance()) return this;
        if (other.getOffset() != 0L) {
          setOffset(other.getOffset());
        }
        if (other.getDone() != false) {
          setDone(other.getDone());
        }
        if (rowsBuilder_ == null) {
          if (!other.rows_.isEmpty()) {
            if (rows_.isEmpty()) {
              rows_ = other.rows_;
              bitField0_ = (bitField0_ & ~0x00000001);
            } else {
              ensureRowsIsMutable();
              rows_.addAll(other.rows_);
            }
            onChanged();
          }
        } else {
          if (!other.rows_.isEmpty()) {
            if (rowsBuilder_.isEmpty()) {
              rowsBuilder_.dispose();
              rowsBuilder_ = null;
              rows_ = other.rows_;
              bitField0_ = (bitField0_ & ~0x00000001);
              rowsBuilder_ = 
                com.google.protobuf.GeneratedMessageV3.alwaysUseFieldBuilders ?
                   getRowsFieldBuilder() : null;
            } else {
              rowsBuilder_.addAllMessages(other.rows_);
            }
          }
        }
        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: {
                offset_ = input.readUInt64();

                break;
              } // case 8
              case 16: {
                done_ = input.readBool();

                break;
              } // case 16
              case 26: {
                org.apache.calcite.avatica.proto.Common.Row m =
                    input.readMessage(
                        org.apache.calcite.avatica.proto.Common.Row.parser(),
                        extensionRegistry);
                if (rowsBuilder_ == null) {
                  ensureRowsIsMutable();
                  rows_.add(m);
                } else {
                  rowsBuilder_.addMessage(m);
                }
                break;
              } // case 26
              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 long offset_ ;
      /**
       * <code>uint64 offset = 1;</code>
       * @return The offset.
       */
      @java.lang.Override
      public long getOffset() {
        return offset_;
      }
      /**
       * <code>uint64 offset = 1;</code>
       * @param value The offset to set.
       * @return This builder for chaining.
       */
      public Builder setOffset(long value) {
        
        offset_ = value;
        onChanged();
        return this;
      }
      /**
       * <code>uint64 offset = 1;</code>
       * @return This builder for chaining.
       */
      public Builder clearOffset() {
        
        offset_ = 0L;
        onChanged();
        return this;
      }

      private boolean done_ ;
      /**
       * <code>bool done = 2;</code>
       * @return The done.
       */
      @java.lang.Override
      public boolean getDone() {
        return done_;
      }
      /**
       * <code>bool done = 2;</code>
       * @param value The done to set.
       * @return This builder for chaining.
       */
      public Builder setDone(boolean value) {
        
        done_ = value;
        onChanged();
        return this;
      }
      /**
       * <code>bool done = 2;</code>
       * @return This builder for chaining.
       */
      public Builder clearDone() {
        
        done_ = false;
        onChanged();
        return this;
      }

      private java.util.List<org.apache.calcite.avatica.proto.Common.Row> rows_ =
        java.util.Collections.emptyList();
      private void ensureRowsIsMutable() {
        if (!((bitField0_ & 0x00000001) != 0)) {
          rows_ = new java.util.ArrayList<org.apache.calcite.avatica.proto.Common.Row>(rows_);
          bitField0_ |= 0x00000001;
         }
      }

      private com.google.protobuf.RepeatedFieldBuilderV3<
          org.apache.calcite.avatica.proto.Common.Row, org.apache.calcite.avatica.proto.Common.Row.Builder, org.apache.calcite.avatica.proto.Common.RowOrBuilder> rowsBuilder_;

      /**
       * <code>repeated .Row rows = 3;</code>
       */
      public java.util.List<org.apache.calcite.avatica.proto.Common.Row> getRowsList() {
        if (rowsBuilder_ == null) {
          return java.util.Collections.unmodifiableList(rows_);
        } else {
          return rowsBuilder_.getMessageList();
        }
      }
      /**
       * <code>repeated .Row rows = 3;</code>
       */
      public int getRowsCount() {
        if (rowsBuilder_ == null) {
          return rows_.size();
        } else {
          return rowsBuilder_.getCount();
        }
      }
      /**
       * <code>repeated .Row rows = 3;</code>
       */
      public org.apache.calcite.avatica.proto.Common.Row getRows(int index) {
        if (rowsBuilder_ == null) {
          return rows_.get(index);
        } else {
          return rowsBuilder_.getMessage(index);
        }
      }
      /**
       * <code>repeated .Row rows = 3;</code>
       */
      public Builder setRows(
          int index, org.apache.calcite.avatica.proto.Common.Row value) {
        if (rowsBuilder_ == null) {
          if (value == null) {
            throw new NullPointerException();
          }
          ensureRowsIsMutable();
          rows_.set(index, value);
          onChanged();
        } else {
          rowsBuilder_.setMessage(index, value);
        }
        return this;
      }
      /**
       * <code>repeated .Row rows = 3;</code>
       */
      public Builder setRows(
          int index, org.apache.calcite.avatica.proto.Common.Row.Builder builderForValue) {
        if (rowsBuilder_ == null) {
          ensureRowsIsMutable();
          rows_.set(index, builderForValue.build());
          onChanged();
        } else {
          rowsBuilder_.setMessage(index, builderForValue.build());
        }
        return this;
      }
      /**
       * <code>repeated .Row rows = 3;</code>
       */
      public Builder addRows(org.apache.calcite.avatica.proto.Common.Row value) {
        if (rowsBuilder_ == null) {
          if (value == null) {
            throw new NullPointerException();
          }
          ensureRowsIsMutable();
          rows_.add(value);
          onChanged();
        } else {
          rowsBuilder_.addMessage(value);
        }
        return this;
      }
      /**
       * <code>repeated .Row rows = 3;</code>
       */
      public Builder addRows(
          int index, org.apache.calcite.avatica.proto.Common.Row value) {
        if (rowsBuilder_ == null) {
          if (value == null) {
            throw new NullPointerException();
          }
          ensureRowsIsMutable();
          rows_.add(index, value);
          onChanged();
        } else {
          rowsBuilder_.addMessage(index, value);
        }
        return this;
      }
      /**
       * <code>repeated .Row rows = 3;</code>
       */
      public Builder addRows(
          org.apache.calcite.avatica.proto.Common.Row.Builder builderForValue) {
        if (rowsBuilder_ == null) {
          ensureRowsIsMutable();
          rows_.add(builderForValue.build());
          onChanged();
        } else {
          rowsBuilder_.addMessage(builderForValue.build());
        }
        return this;
      }
      /**
       * <code>repeated .Row rows = 3;</code>
       */
      public Builder addRows(
          int index, org.apache.calcite.avatica.proto.Common.Row.Builder builderForValue) {
        if (rowsBuilder_ == null) {
          ensureRowsIsMutable();
          rows_.add(index, builderForValue.build());
          onChanged();
        } else {
          rowsBuilder_.addMessage(index, builderForValue.build());
        }
        return this;
      }
      /**
       * <code>repeated .Row rows = 3;</code>
       */
      public Builder addAllRows(
          java.lang.Iterable<? extends org.apache.calcite.avatica.proto.Common.Row> values) {
        if (rowsBuilder_ == null) {
          ensureRowsIsMutable();
          com.google.protobuf.AbstractMessageLite.Builder.addAll(
              values, rows_);
          onChanged();
        } else {
          rowsBuilder_.addAllMessages(values);
        }
        return this;
      }
      /**
       * <code>repeated .Row rows = 3;</code>
       */
      public Builder clearRows() {
        if (rowsBuilder_ == null) {
          rows_ = java.util.Collections.emptyList();
          bitField0_ = (bitField0_ & ~0x00000001);
          onChanged();
        } else {
          rowsBuilder_.clear();
        }
        return this;
      }
      /**
       * <code>repeated .Row rows = 3;</code>
       */
      public Builder removeRows(int index) {
        if (rowsBuilder_ == null) {
          ensureRowsIsMutable();
          rows_.remove(index);
          onChanged();
        } else {
          rowsBuilder_.remove(index);
        }
        return this;
      }
      /**
       * <code>repeated .Row rows = 3;</code>
       */
      public org.apache.calcite.avatica.proto.Common.Row.Builder getRowsBuilder(
          int index) {
        return getRowsFieldBuilder().getBuilder(index);
      }
      /**
       * <code>repeated .Row rows = 3;</code>
       */
      public org.apache.calcite.avatica.proto.Common.RowOrBuilder getRowsOrBuilder(
          int index) {
        if (rowsBuilder_ == null) {
          return rows_.get(index);  } else {
          return rowsBuilder_.getMessageOrBuilder(index);
        }
      }
      /**
       * <code>repeated .Row rows = 3;</code>
       */
      public java.util.List<? extends org.apache.calcite.avatica.proto.Common.RowOrBuilder> 
           getRowsOrBuilderList() {
        if (rowsBuilder_ != null) {
          return rowsBuilder_.getMessageOrBuilderList();
        } else {
          return java.util.Collections.unmodifiableList(rows_);
        }
      }
      /**
       * <code>repeated .Row rows = 3;</code>
       */
      public org.apache.calcite.avatica.proto.Common.Row.Builder addRowsBuilder() {
        return getRowsFieldBuilder().addBuilder(
            org.apache.calcite.avatica.proto.Common.Row.getDefaultInstance());
      }
      /**
       * <code>repeated .Row rows = 3;</code>
       */
      public org.apache.calcite.avatica.proto.Common.Row.Builder addRowsBuilder(
          int index) {
        return getRowsFieldBuilder().addBuilder(
            index, org.apache.calcite.avatica.proto.Common.Row.getDefaultInstance());
      }
      /**
       * <code>repeated .Row rows = 3;</code>
       */
      public java.util.List<org.apache.calcite.avatica.proto.Common.Row.Builder> 
           getRowsBuilderList() {
        return getRowsFieldBuilder().getBuilderList();
      }
      private com.google.protobuf.RepeatedFieldBuilderV3<
          org.apache.calcite.avatica.proto.Common.Row, org.apache.calcite.avatica.proto.Common.Row.Builder, org.apache.calcite.avatica.proto.Common.RowOrBuilder> 
          getRowsFieldBuilder() {
        if (rowsBuilder_ == null) {
          rowsBuilder_ = new com.google.protobuf.RepeatedFieldBuilderV3<
              org.apache.calcite.avatica.proto.Common.Row, org.apache.calcite.avatica.proto.Common.Row.Builder, org.apache.calcite.avatica.proto.Common.RowOrBuilder>(
                  rows_,
                  ((bitField0_ & 0x00000001) != 0),
                  getParentForChildren(),
                  isClean());
          rows_ = null;
        }
        return rowsBuilder_;
      }
      @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:Frame)
    }

    // @@protoc_insertion_point(class_scope:Frame)
    private static final org.apache.calcite.avatica.proto.Common.Frame DEFAULT_INSTANCE;
    static {
      DEFAULT_INSTANCE = new org.apache.calcite.avatica.proto.Common.Frame();
    }

    public static org.apache.calcite.avatica.proto.Common.Frame getDefaultInstance() {
      return DEFAULT_INSTANCE;
    }

    private static final com.google.protobuf.Parser<Frame>
        PARSER = new com.google.protobuf.AbstractParser<Frame>() {
      @java.lang.Override
      public Frame 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<Frame> parser() {
      return PARSER;
    }

    @java.lang.Override
    public com.google.protobuf.Parser<Frame> getParserForType() {
      return PARSER;
    }

    @java.lang.Override
    public org.apache.calcite.avatica.proto.Common.Frame getDefaultInstanceForType() {
      return DEFAULT_INSTANCE;
    }

  }

  public interface RowOrBuilder extends
      // @@protoc_insertion_point(interface_extends:Row)
      com.google.protobuf.MessageOrBuilder {

    /**
     * <code>repeated .ColumnValue value = 1;</code>
     */
    java.util.List<org.apache.calcite.avatica.proto.Common.ColumnValue> 
        getValueList();
    /**
     * <code>repeated .ColumnValue value = 1;</code>
     */
    org.apache.calcite.avatica.proto.Common.ColumnValue getValue(int index);
    /**
     * <code>repeated .ColumnValue value = 1;</code>
     */
    int getValueCount();
    /**
     * <code>repeated .ColumnValue value = 1;</code>
     */
    java.util.List<? extends org.apache.calcite.avatica.proto.Common.ColumnValueOrBuilder> 
        getValueOrBuilderList();
    /**
     * <code>repeated .ColumnValue value = 1;</code>
     */
    org.apache.calcite.avatica.proto.Common.ColumnValueOrBuilder getValueOrBuilder(
        int index);
  }
  /**
   * <pre>
   * A row is a collection of values
   * </pre>
   *
   * Protobuf type {@code Row}
   */
  public static final class Row extends
      com.google.protobuf.GeneratedMessageV3 implements
      // @@protoc_insertion_point(message_implements:Row)
      RowOrBuilder {
  private static final long serialVersionUID = 0L;
    // Use Row.newBuilder() to construct.
    private Row(com.google.protobuf.GeneratedMessageV3.Builder<?> builder) {
      super(builder);
    }
    private Row() {
      value_ = java.util.Collections.emptyList();
    }

    @java.lang.Override
    @SuppressWarnings({"unused"})
    protected java.lang.Object newInstance(
        UnusedPrivateParameter unused) {
      return new Row();
    }

    @java.lang.Override
    public final com.google.protobuf.UnknownFieldSet
    getUnknownFields() {
      return this.unknownFields;
    }
    public static final com.google.protobuf.Descriptors.Descriptor
        getDescriptor() {
      return org.apache.calcite.avatica.proto.Common.internal_static_Row_descriptor;
    }

    @java.lang.Override
    protected com.google.protobuf.GeneratedMessageV3.FieldAccessorTable
        internalGetFieldAccessorTable() {
      return org.apache.calcite.avatica.proto.Common.internal_static_Row_fieldAccessorTable
          .ensureFieldAccessorsInitialized(
              org.apache.calcite.avatica.proto.Common.Row.class, org.apache.calcite.avatica.proto.Common.Row.Builder.class);
    }

    public static final int VALUE_FIELD_NUMBER = 1;
    private java.util.List<org.apache.calcite.avatica.proto.Common.ColumnValue> value_;
    /**
     * <code>repeated .ColumnValue value = 1;</code>
     */
    @java.lang.Override
    public java.util.List<org.apache.calcite.avatica.proto.Common.ColumnValue> getValueList() {
      return value_;
    }
    /**
     * <code>repeated .ColumnValue value = 1;</code>
     */
    @java.lang.Override
    public java.util.List<? extends org.apache.calcite.avatica.proto.Common.ColumnValueOrBuilder> 
        getValueOrBuilderList() {
      return value_;
    }
    /**
     * <code>repeated .ColumnValue value = 1;</code>
     */
    @java.lang.Override
    public int getValueCount() {
      return value_.size();
    }
    /**
     * <code>repeated .ColumnValue value = 1;</code>
     */
    @java.lang.Override
    public org.apache.calcite.avatica.proto.Common.ColumnValue getValue(int index) {
      return value_.get(index);
    }
    /**
     * <code>repeated .ColumnValue value = 1;</code>
     */
    @java.lang.Override
    public org.apache.calcite.avatica.proto.Common.ColumnValueOrBuilder getValueOrBuilder(
        int index) {
      return value_.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 {
      for (int i = 0; i < value_.size(); i++) {
        output.writeMessage(1, value_.get(i));
      }
      getUnknownFields().writeTo(output);
    }

    @java.lang.Override
    public int getSerializedSize() {
      int size = memoizedSize;
      if (size != -1) return size;

      size = 0;
      for (int i = 0; i < value_.size(); i++) {
        size += com.google.protobuf.CodedOutputStream
          .computeMessageSize(1, value_.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 org.apache.calcite.avatica.proto.Common.Row)) {
        return super.equals(obj);
      }
      org.apache.calcite.avatica.proto.Common.Row other = (org.apache.calcite.avatica.proto.Common.Row) obj;

      if (!getValueList()
          .equals(other.getValueList())) 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 (getValueCount() > 0) {
        hash = (37 * hash) + VALUE_FIELD_NUMBER;
        hash = (53 * hash) + getValueList().hashCode();
      }
      hash = (29 * hash) + getUnknownFields().hashCode();
      memoizedHashCode = hash;
      return hash;
    }

    public static org.apache.calcite.avatica.proto.Common.Row parseFrom(
        java.nio.ByteBuffer data)
        throws com.google.protobuf.InvalidProtocolBufferException {
      return PARSER.parseFrom(data);
    }
    public static org.apache.calcite.avatica.proto.Common.Row parseFrom(
        java.nio.ByteBuffer data,
        com.google.protobuf.ExtensionRegistryLite extensionRegistry)
        throws com.google.protobuf.InvalidProtocolBufferException {
      return PARSER.parseFrom(data, extensionRegistry);
    }
    public static org.apache.calcite.avatica.proto.Common.Row parseFrom(
        com.google.protobuf.ByteString data)
        throws com.google.protobuf.InvalidProtocolBufferException {
      return PARSER.parseFrom(data);
    }
    public static org.apache.calcite.avatica.proto.Common.Row parseFrom(
        com.google.protobuf.ByteString data,
        com.google.protobuf.ExtensionRegistryLite extensionRegistry)
        throws com.google.protobuf.InvalidProtocolBufferException {
      return PARSER.parseFrom(data, extensionRegistry);
    }
    public static org.apache.calcite.avatica.proto.Common.Row parseFrom(byte[] data)
        throws com.google.protobuf.InvalidProtocolBufferException {
      return PARSER.parseFrom(data);
    }
    public static org.apache.calcite.avatica.proto.Common.Row parseFrom(
        byte[] data,
        com.google.protobuf.ExtensionRegistryLite extensionRegistry)
        throws com.google.protobuf.InvalidProtocolBufferException {
      return PARSER.parseFrom(data, extensionRegistry);
    }
    public static org.apache.calcite.avatica.proto.Common.Row parseFrom(java.io.InputStream input)
        throws java.io.IOException {
      return com.google.protobuf.GeneratedMessageV3
          .parseWithIOException(PARSER, input);
    }
    public static org.apache.calcite.avatica.proto.Common.Row 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 org.apache.calcite.avatica.proto.Common.Row parseDelimitedFrom(java.io.InputStream input)
        throws java.io.IOException {
      return com.google.protobuf.GeneratedMessageV3
          .parseDelimitedWithIOException(PARSER, input);
    }
    public static org.apache.calcite.avatica.proto.Common.Row 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 org.apache.calcite.avatica.proto.Common.Row parseFrom(
        com.google.protobuf.CodedInputStream input)
        throws java.io.IOException {
      return com.google.protobuf.GeneratedMessageV3
          .parseWithIOException(PARSER, input);
    }
    public static org.apache.calcite.avatica.proto.Common.Row 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(org.apache.calcite.avatica.proto.Common.Row 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;
    }
    /**
     * <pre>
     * A row is a collection of values
     * </pre>
     *
     * Protobuf type {@code Row}
     */
    public static final class Builder extends
        com.google.protobuf.GeneratedMessageV3.Builder<Builder> implements
        // @@protoc_insertion_point(builder_implements:Row)
        org.apache.calcite.avatica.proto.Common.RowOrBuilder {
      public static final com.google.protobuf.Descriptors.Descriptor
          getDescriptor() {
        return org.apache.calcite.avatica.proto.Common.internal_static_Row_descriptor;
      }

      @java.lang.Override
      protected com.google.protobuf.GeneratedMessageV3.FieldAccessorTable
          internalGetFieldAccessorTable() {
        return org.apache.calcite.avatica.proto.Common.internal_static_Row_fieldAccessorTable
            .ensureFieldAccessorsInitialized(
                org.apache.calcite.avatica.proto.Common.Row.class, org.apache.calcite.avatica.proto.Common.Row.Builder.class);
      }

      // Construct using org.apache.calcite.avatica.proto.Common.Row.newBuilder()
      private Builder() {

      }

      private Builder(
          com.google.protobuf.GeneratedMessageV3.BuilderParent parent) {
        super(parent);

      }
      @java.lang.Override
      public Builder clear() {
        super.clear();
        if (valueBuilder_ == null) {
          value_ = java.util.Collections.emptyList();
        } else {
          value_ = null;
          valueBuilder_.clear();
        }
        bitField0_ = (bitField0_ & ~0x00000001);
        return this;
      }

      @java.lang.Override
      public com.google.protobuf.Descriptors.Descriptor
          getDescriptorForType() {
        return org.apache.calcite.avatica.proto.Common.internal_static_Row_descriptor;
      }

      @java.lang.Override
      public org.apache.calcite.avatica.proto.Common.Row getDefaultInstanceForType() {
        return org.apache.calcite.avatica.proto.Common.Row.getDefaultInstance();
      }

      @java.lang.Override
      public org.apache.calcite.avatica.proto.Common.Row build() {
        org.apache.calcite.avatica.proto.Common.Row result = buildPartial();
        if (!result.isInitialized()) {
          throw newUninitializedMessageException(result);
        }
        return result;
      }

      @java.lang.Override
      public org.apache.calcite.avatica.proto.Common.Row buildPartial() {
        org.apache.calcite.avatica.proto.Common.Row result = new org.apache.calcite.avatica.proto.Common.Row(this);
        int from_bitField0_ = bitField0_;
        if (valueBuilder_ == null) {
          if (((bitField0_ & 0x00000001) != 0)) {
            value_ = java.util.Collections.unmodifiableList(value_);
            bitField0_ = (bitField0_ & ~0x00000001);
          }
          result.value_ = value_;
        } else {
          result.value_ = valueBuilder_.build();
        }
        onBuilt();
        return result;
      }

      @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 org.apache.calcite.avatica.proto.Common.Row) {
          return mergeFrom((org.apache.calcite.avatica.proto.Common.Row)other);
        } else {
          super.mergeFrom(other);
          return this;
        }
      }

      public Builder mergeFrom(org.apache.calcite.avatica.proto.Common.Row other) {
        if (other == org.apache.calcite.avatica.proto.Common.Row.getDefaultInstance()) return this;
        if (valueBuilder_ == null) {
          if (!other.value_.isEmpty()) {
            if (value_.isEmpty()) {
              value_ = other.value_;
              bitField0_ = (bitField0_ & ~0x00000001);
            } else {
              ensureValueIsMutable();
              value_.addAll(other.value_);
            }
            onChanged();
          }
        } else {
          if (!other.value_.isEmpty()) {
            if (valueBuilder_.isEmpty()) {
              valueBuilder_.dispose();
              valueBuilder_ = null;
              value_ = other.value_;
              bitField0_ = (bitField0_ & ~0x00000001);
              valueBuilder_ = 
                com.google.protobuf.GeneratedMessageV3.alwaysUseFieldBuilders ?
                   getValueFieldBuilder() : null;
            } else {
              valueBuilder_.addAllMessages(other.value_);
            }
          }
        }
        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: {
                org.apache.calcite.avatica.proto.Common.ColumnValue m =
                    input.readMessage(
                        org.apache.calcite.avatica.proto.Common.ColumnValue.parser(),
                        extensionRegistry);
                if (valueBuilder_ == null) {
                  ensureValueIsMutable();
                  value_.add(m);
                } else {
                  valueBuilder_.addMessage(m);
                }
                break;
              } // case 10
              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.util.List<org.apache.calcite.avatica.proto.Common.ColumnValue> value_ =
        java.util.Collections.emptyList();
      private void ensureValueIsMutable() {
        if (!((bitField0_ & 0x00000001) != 0)) {
          value_ = new java.util.ArrayList<org.apache.calcite.avatica.proto.Common.ColumnValue>(value_);
          bitField0_ |= 0x00000001;
         }
      }

      private com.google.protobuf.RepeatedFieldBuilderV3<
          org.apache.calcite.avatica.proto.Common.ColumnValue, org.apache.calcite.avatica.proto.Common.ColumnValue.Builder, org.apache.calcite.avatica.proto.Common.ColumnValueOrBuilder> valueBuilder_;

      /**
       * <code>repeated .ColumnValue value = 1;</code>
       */
      public java.util.List<org.apache.calcite.avatica.proto.Common.ColumnValue> getValueList() {
        if (valueBuilder_ == null) {
          return java.util.Collections.unmodifiableList(value_);
        } else {
          return valueBuilder_.getMessageList();
        }
      }
      /**
       * <code>repeated .ColumnValue value = 1;</code>
       */
      public int getValueCount() {
        if (valueBuilder_ == null) {
          return value_.size();
        } else {
          return valueBuilder_.getCount();
        }
      }
      /**
       * <code>repeated .ColumnValue value = 1;</code>
       */
      public org.apache.calcite.avatica.proto.Common.ColumnValue getValue(int index) {
        if (valueBuilder_ == null) {
          return value_.get(index);
        } else {
          return valueBuilder_.getMessage(index);
        }
      }
      /**
       * <code>repeated .ColumnValue value = 1;</code>
       */
      public Builder setValue(
          int index, org.apache.calcite.avatica.proto.Common.ColumnValue value) {
        if (valueBuilder_ == null) {
          if (value == null) {
            throw new NullPointerException();
          }
          ensureValueIsMutable();
          value_.set(index, value);
          onChanged();
        } else {
          valueBuilder_.setMessage(index, value);
        }
        return this;
      }
      /**
       * <code>repeated .ColumnValue value = 1;</code>
       */
      public Builder setValue(
          int index, org.apache.calcite.avatica.proto.Common.ColumnValue.Builder builderForValue) {
        if (valueBuilder_ == null) {
          ensureValueIsMutable();
          value_.set(index, builderForValue.build());
          onChanged();
        } else {
          valueBuilder_.setMessage(index, builderForValue.build());
        }
        return this;
      }
      /**
       * <code>repeated .ColumnValue value = 1;</code>
       */
      public Builder addValue(org.apache.calcite.avatica.proto.Common.ColumnValue value) {
        if (valueBuilder_ == null) {
          if (value == null) {
            throw new NullPointerException();
          }
          ensureValueIsMutable();
          value_.add(value);
          onChanged();
        } else {
          valueBuilder_.addMessage(value);
        }
        return this;
      }
      /**
       * <code>repeated .ColumnValue value = 1;</code>
       */
      public Builder addValue(
          int index, org.apache.calcite.avatica.proto.Common.ColumnValue value) {
        if (valueBuilder_ == null) {
          if (value == null) {
            throw new NullPointerException();
          }
          ensureValueIsMutable();
          value_.add(index, value);
          onChanged();
        } else {
          valueBuilder_.addMessage(index, value);
        }
        return this;
      }
      /**
       * <code>repeated .ColumnValue value = 1;</code>
       */
      public Builder addValue(
          org.apache.calcite.avatica.proto.Common.ColumnValue.Builder builderForValue) {
        if (valueBuilder_ == null) {
          ensureValueIsMutable();
          value_.add(builderForValue.build());
          onChanged();
        } else {
          valueBuilder_.addMessage(builderForValue.build());
        }
        return this;
      }
      /**
       * <code>repeated .ColumnValue value = 1;</code>
       */
      public Builder addValue(
          int index, org.apache.calcite.avatica.proto.Common.ColumnValue.Builder builderForValue) {
        if (valueBuilder_ == null) {
          ensureValueIsMutable();
          value_.add(index, builderForValue.build());
          onChanged();
        } else {
          valueBuilder_.addMessage(index, builderForValue.build());
        }
        return this;
      }
      /**
       * <code>repeated .ColumnValue value = 1;</code>
       */
      public Builder addAllValue(
          java.lang.Iterable<? extends org.apache.calcite.avatica.proto.Common.ColumnValue> values) {
        if (valueBuilder_ == null) {
          ensureValueIsMutable();
          com.google.protobuf.AbstractMessageLite.Builder.addAll(
              values, value_);
          onChanged();
        } else {
          valueBuilder_.addAllMessages(values);
        }
        return this;
      }
      /**
       * <code>repeated .ColumnValue value = 1;</code>
       */
      public Builder clearValue() {
        if (valueBuilder_ == null) {
          value_ = java.util.Collections.emptyList();
          bitField0_ = (bitField0_ & ~0x00000001);
          onChanged();
        } else {
          valueBuilder_.clear();
        }
        return this;
      }
      /**
       * <code>repeated .ColumnValue value = 1;</code>
       */
      public Builder removeValue(int index) {
        if (valueBuilder_ == null) {
          ensureValueIsMutable();
          value_.remove(index);
          onChanged();
        } else {
          valueBuilder_.remove(index);
        }
        return this;
      }
      /**
       * <code>repeated .ColumnValue value = 1;</code>
       */
      public org.apache.calcite.avatica.proto.Common.ColumnValue.Builder getValueBuilder(
          int index) {
        return getValueFieldBuilder().getBuilder(index);
      }
      /**
       * <code>repeated .ColumnValue value = 1;</code>
       */
      public org.apache.calcite.avatica.proto.Common.ColumnValueOrBuilder getValueOrBuilder(
          int index) {
        if (valueBuilder_ == null) {
          return value_.get(index);  } else {
          return valueBuilder_.getMessageOrBuilder(index);
        }
      }
      /**
       * <code>repeated .ColumnValue value = 1;</code>
       */
      public java.util.List<? extends org.apache.calcite.avatica.proto.Common.ColumnValueOrBuilder> 
           getValueOrBuilderList() {
        if (valueBuilder_ != null) {
          return valueBuilder_.getMessageOrBuilderList();
        } else {
          return java.util.Collections.unmodifiableList(value_);
        }
      }
      /**
       * <code>repeated .ColumnValue value = 1;</code>
       */
      public org.apache.calcite.avatica.proto.Common.ColumnValue.Builder addValueBuilder() {
        return getValueFieldBuilder().addBuilder(
            org.apache.calcite.avatica.proto.Common.ColumnValue.getDefaultInstance());
      }
      /**
       * <code>repeated .ColumnValue value = 1;</code>
       */
      public org.apache.calcite.avatica.proto.Common.ColumnValue.Builder addValueBuilder(
          int index) {
        return getValueFieldBuilder().addBuilder(
            index, org.apache.calcite.avatica.proto.Common.ColumnValue.getDefaultInstance());
      }
      /**
       * <code>repeated .ColumnValue value = 1;</code>
       */
      public java.util.List<org.apache.calcite.avatica.proto.Common.ColumnValue.Builder> 
           getValueBuilderList() {
        return getValueFieldBuilder().getBuilderList();
      }
      private com.google.protobuf.RepeatedFieldBuilderV3<
          org.apache.calcite.avatica.proto.Common.ColumnValue, org.apache.calcite.avatica.proto.Common.ColumnValue.Builder, org.apache.calcite.avatica.proto.Common.ColumnValueOrBuilder> 
          getValueFieldBuilder() {
        if (valueBuilder_ == null) {
          valueBuilder_ = new com.google.protobuf.RepeatedFieldBuilderV3<
              org.apache.calcite.avatica.proto.Common.ColumnValue, org.apache.calcite.avatica.proto.Common.ColumnValue.Builder, org.apache.calcite.avatica.proto.Common.ColumnValueOrBuilder>(
                  value_,
                  ((bitField0_ & 0x00000001) != 0),
                  getParentForChildren(),
                  isClean());
          value_ = null;
        }
        return valueBuilder_;
      }
      @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:Row)
    }

    // @@protoc_insertion_point(class_scope:Row)
    private static final org.apache.calcite.avatica.proto.Common.Row DEFAULT_INSTANCE;
    static {
      DEFAULT_INSTANCE = new org.apache.calcite.avatica.proto.Common.Row();
    }

    public static org.apache.calcite.avatica.proto.Common.Row getDefaultInstance() {
      return DEFAULT_INSTANCE;
    }

    private static final com.google.protobuf.Parser<Row>
        PARSER = new com.google.protobuf.AbstractParser<Row>() {
      @java.lang.Override
      public Row 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<Row> parser() {
      return PARSER;
    }

    @java.lang.Override
    public com.google.protobuf.Parser<Row> getParserForType() {
      return PARSER;
    }

    @java.lang.Override
    public org.apache.calcite.avatica.proto.Common.Row getDefaultInstanceForType() {
      return DEFAULT_INSTANCE;
    }

  }

  public interface DatabasePropertyOrBuilder extends
      // @@protoc_insertion_point(interface_extends:DatabaseProperty)
      com.google.protobuf.MessageOrBuilder {

    /**
     * <code>string name = 1;</code>
     * @return The name.
     */
    java.lang.String getName();
    /**
     * <code>string name = 1;</code>
     * @return The bytes for name.
     */
    com.google.protobuf.ByteString
        getNameBytes();

    /**
     * <code>repeated string functions = 2;</code>
     * @return A list containing the functions.
     */
    java.util.List<java.lang.String>
        getFunctionsList();
    /**
     * <code>repeated string functions = 2;</code>
     * @return The count of functions.
     */
    int getFunctionsCount();
    /**
     * <code>repeated string functions = 2;</code>
     * @param index The index of the element to return.
     * @return The functions at the given index.
     */
    java.lang.String getFunctions(int index);
    /**
     * <code>repeated string functions = 2;</code>
     * @param index The index of the value to return.
     * @return The bytes of the functions at the given index.
     */
    com.google.protobuf.ByteString
        getFunctionsBytes(int index);
  }
  /**
   * <pre>
   * Database property, list of functions the database provides for a certain operation
   * </pre>
   *
   * Protobuf type {@code DatabaseProperty}
   */
  public static final class DatabaseProperty extends
      com.google.protobuf.GeneratedMessageV3 implements
      // @@protoc_insertion_point(message_implements:DatabaseProperty)
      DatabasePropertyOrBuilder {
  private static final long serialVersionUID = 0L;
    // Use DatabaseProperty.newBuilder() to construct.
    private DatabaseProperty(com.google.protobuf.GeneratedMessageV3.Builder<?> builder) {
      super(builder);
    }
    private DatabaseProperty() {
      name_ = "";
      functions_ = com.google.protobuf.LazyStringArrayList.EMPTY;
    }

    @java.lang.Override
    @SuppressWarnings({"unused"})
    protected java.lang.Object newInstance(
        UnusedPrivateParameter unused) {
      return new DatabaseProperty();
    }

    @java.lang.Override
    public final com.google.protobuf.UnknownFieldSet
    getUnknownFields() {
      return this.unknownFields;
    }
    public static final com.google.protobuf.Descriptors.Descriptor
        getDescriptor() {
      return org.apache.calcite.avatica.proto.Common.internal_static_DatabaseProperty_descriptor;
    }

    @java.lang.Override
    protected com.google.protobuf.GeneratedMessageV3.FieldAccessorTable
        internalGetFieldAccessorTable() {
      return org.apache.calcite.avatica.proto.Common.internal_static_DatabaseProperty_fieldAccessorTable
          .ensureFieldAccessorsInitialized(
              org.apache.calcite.avatica.proto.Common.DatabaseProperty.class, org.apache.calcite.avatica.proto.Common.DatabaseProperty.Builder.class);
    }

    public static final int NAME_FIELD_NUMBER = 1;
    private volatile java.lang.Object name_;
    /**
     * <code>string name = 1;</code>
     * @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();
        name_ = s;
        return s;
      }
    }
    /**
     * <code>string name = 1;</code>
     * @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 FUNCTIONS_FIELD_NUMBER = 2;
    private com.google.protobuf.LazyStringList functions_;
    /**
     * <code>repeated string functions = 2;</code>
     * @return A list containing the functions.
     */
    public com.google.protobuf.ProtocolStringList
        getFunctionsList() {
      return functions_;
    }
    /**
     * <code>repeated string functions = 2;</code>
     * @return The count of functions.
     */
    public int getFunctionsCount() {
      return functions_.size();
    }
    /**
     * <code>repeated string functions = 2;</code>
     * @param index The index of the element to return.
     * @return The functions at the given index.
     */
    public java.lang.String getFunctions(int index) {
      return functions_.get(index);
    }
    /**
     * <code>repeated string functions = 2;</code>
     * @param index The index of the value to return.
     * @return The bytes of the functions at the given index.
     */
    public com.google.protobuf.ByteString
        getFunctionsBytes(int index) {
      return functions_.getByteString(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 (!com.google.protobuf.GeneratedMessageV3.isStringEmpty(name_)) {
        com.google.protobuf.GeneratedMessageV3.writeString(output, 1, name_);
      }
      for (int i = 0; i < functions_.size(); i++) {
        com.google.protobuf.GeneratedMessageV3.writeString(output, 2, functions_.getRaw(i));
      }
      getUnknownFields().writeTo(output);
    }

    @java.lang.Override
    public int getSerializedSize() {
      int size = memoizedSize;
      if (size != -1) return size;

      size = 0;
      if (!com.google.protobuf.GeneratedMessageV3.isStringEmpty(name_)) {
        size += com.google.protobuf.GeneratedMessageV3.computeStringSize(1, name_);
      }
      {
        int dataSize = 0;
        for (int i = 0; i < functions_.size(); i++) {
          dataSize += computeStringSizeNoTag(functions_.getRaw(i));
        }
        size += dataSize;
        size += 1 * getFunctionsList().size();
      }
      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 org.apache.calcite.avatica.proto.Common.DatabaseProperty)) {
        return super.equals(obj);
      }
      org.apache.calcite.avatica.proto.Common.DatabaseProperty other = (org.apache.calcite.avatica.proto.Common.DatabaseProperty) obj;

      if (!getName()
          .equals(other.getName())) return false;
      if (!getFunctionsList()
          .equals(other.getFunctionsList())) 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();
      hash = (37 * hash) + NAME_FIELD_NUMBER;
      hash = (53 * hash) + getName().hashCode();
      if (getFunctionsCount() > 0) {
        hash = (37 * hash) + FUNCTIONS_FIELD_NUMBER;
        hash = (53 * hash) + getFunctionsList().hashCode();
      }
      hash = (29 * hash) + getUnknownFields().hashCode();
      memoizedHashCode = hash;
      return hash;
    }

    public static org.apache.calcite.avatica.proto.Common.DatabaseProperty parseFrom(
        java.nio.ByteBuffer data)
        throws com.google.protobuf.InvalidProtocolBufferException {
      return PARSER.parseFrom(data);
    }
    public static org.apache.calcite.avatica.proto.Common.DatabaseProperty parseFrom(
        java.nio.ByteBuffer data,
        com.google.protobuf.ExtensionRegistryLite extensionRegistry)
        throws com.google.protobuf.InvalidProtocolBufferException {
      return PARSER.parseFrom(data, extensionRegistry);
    }
    public static org.apache.calcite.avatica.proto.Common.DatabaseProperty parseFrom(
        com.google.protobuf.ByteString data)
        throws com.google.protobuf.InvalidProtocolBufferException {
      return PARSER.parseFrom(data);
    }
    public static org.apache.calcite.avatica.proto.Common.DatabaseProperty parseFrom(
        com.google.protobuf.ByteString data,
        com.google.protobuf.ExtensionRegistryLite extensionRegistry)
        throws com.google.protobuf.InvalidProtocolBufferException {
      return PARSER.parseFrom(data, extensionRegistry);
    }
    public static org.apache.calcite.avatica.proto.Common.DatabaseProperty parseFrom(byte[] data)
        throws com.google.protobuf.InvalidProtocolBufferException {
      return PARSER.parseFrom(data);
    }
    public static org.apache.calcite.avatica.proto.Common.DatabaseProperty parseFrom(
        byte[] data,
        com.google.protobuf.ExtensionRegistryLite extensionRegistry)
        throws com.google.protobuf.InvalidProtocolBufferException {
      return PARSER.parseFrom(data, extensionRegistry);
    }
    public static org.apache.calcite.avatica.proto.Common.DatabaseProperty parseFrom(java.io.InputStream input)
        throws java.io.IOException {
      return com.google.protobuf.GeneratedMessageV3
          .parseWithIOException(PARSER, input);
    }
    public static org.apache.calcite.avatica.proto.Common.DatabaseProperty 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 org.apache.calcite.avatica.proto.Common.DatabaseProperty parseDelimitedFrom(java.io.InputStream input)
        throws java.io.IOException {
      return com.google.protobuf.GeneratedMessageV3
          .parseDelimitedWithIOException(PARSER, input);
    }
    public static org.apache.calcite.avatica.proto.Common.DatabaseProperty 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 org.apache.calcite.avatica.proto.Common.DatabaseProperty parseFrom(
        com.google.protobuf.CodedInputStream input)
        throws java.io.IOException {
      return com.google.protobuf.GeneratedMessageV3
          .parseWithIOException(PARSER, input);
    }
    public static org.apache.calcite.avatica.proto.Common.DatabaseProperty 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(org.apache.calcite.avatica.proto.Common.DatabaseProperty 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;
    }
    /**
     * <pre>
     * Database property, list of functions the database provides for a certain operation
     * </pre>
     *
     * Protobuf type {@code DatabaseProperty}
     */
    public static final class Builder extends
        com.google.protobuf.GeneratedMessageV3.Builder<Builder> implements
        // @@protoc_insertion_point(builder_implements:DatabaseProperty)
        org.apache.calcite.avatica.proto.Common.DatabasePropertyOrBuilder {
      public static final com.google.protobuf.Descriptors.Descriptor
          getDescriptor() {
        return org.apache.calcite.avatica.proto.Common.internal_static_DatabaseProperty_descriptor;
      }

      @java.lang.Override
      protected com.google.protobuf.GeneratedMessageV3.FieldAccessorTable
          internalGetFieldAccessorTable() {
        return org.apache.calcite.avatica.proto.Common.internal_static_DatabaseProperty_fieldAccessorTable
            .ensureFieldAccessorsInitialized(
                org.apache.calcite.avatica.proto.Common.DatabaseProperty.class, org.apache.calcite.avatica.proto.Common.DatabaseProperty.Builder.class);
      }

      // Construct using org.apache.calcite.avatica.proto.Common.DatabaseProperty.newBuilder()
      private Builder() {

      }

      private Builder(
          com.google.protobuf.GeneratedMessageV3.BuilderParent parent) {
        super(parent);

      }
      @java.lang.Override
      public Builder clear() {
        super.clear();
        name_ = "";

        functions_ = com.google.protobuf.LazyStringArrayList.EMPTY;
        bitField0_ = (bitField0_ & ~0x00000001);
        return this;
      }

      @java.lang.Override
      public com.google.protobuf.Descriptors.Descriptor
          getDescriptorForType() {
        return org.apache.calcite.avatica.proto.Common.internal_static_DatabaseProperty_descriptor;
      }

      @java.lang.Override
      public org.apache.calcite.avatica.proto.Common.DatabaseProperty getDefaultInstanceForType() {
        return org.apache.calcite.avatica.proto.Common.DatabaseProperty.getDefaultInstance();
      }

      @java.lang.Override
      public org.apache.calcite.avatica.proto.Common.DatabaseProperty build() {
        org.apache.calcite.avatica.proto.Common.DatabaseProperty result = buildPartial();
        if (!result.isInitialized()) {
          throw newUninitializedMessageException(result);
        }
        return result;
      }

      @java.lang.Override
      public org.apache.calcite.avatica.proto.Common.DatabaseProperty buildPartial() {
        org.apache.calcite.avatica.proto.Common.DatabaseProperty result = new org.apache.calcite.avatica.proto.Common.DatabaseProperty(this);
        int from_bitField0_ = bitField0_;
        result.name_ = name_;
        if (((bitField0_ & 0x00000001) != 0)) {
          functions_ = functions_.getUnmodifiableView();
          bitField0_ = (bitField0_ & ~0x00000001);
        }
        result.functions_ = functions_;
        onBuilt();
        return result;
      }

      @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 org.apache.calcite.avatica.proto.Common.DatabaseProperty) {
          return mergeFrom((org.apache.calcite.avatica.proto.Common.DatabaseProperty)other);
        } else {
          super.mergeFrom(other);
          return this;
        }
      }

      public Builder mergeFrom(org.apache.calcite.avatica.proto.Common.DatabaseProperty other) {
        if (other == org.apache.calcite.avatica.proto.Common.DatabaseProperty.getDefaultInstance()) return this;
        if (!other.getName().isEmpty()) {
          name_ = other.name_;
          onChanged();
        }
        if (!other.functions_.isEmpty()) {
          if (functions_.isEmpty()) {
            functions_ = other.functions_;
            bitField0_ = (bitField0_ & ~0x00000001);
          } else {
            ensureFunctionsIsMutable();
            functions_.addAll(other.functions_);
          }
          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 10: {
                name_ = input.readStringRequireUtf8();

                break;
              } // case 10
              case 18: {
                java.lang.String s = input.readStringRequireUtf8();
                ensureFunctionsIsMutable();
                functions_.add(s);
                break;
              } // case 18
              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_ = "";
      /**
       * <code>string name = 1;</code>
       * @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();
          name_ = s;
          return s;
        } else {
          return (java.lang.String) ref;
        }
      }
      /**
       * <code>string name = 1;</code>
       * @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;
        }
      }
      /**
       * <code>string name = 1;</code>
       * @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;
        onChanged();
        return this;
      }
      /**
       * <code>string name = 1;</code>
       * @return This builder for chaining.
       */
      public Builder clearName() {
        
        name_ = getDefaultInstance().getName();
        onChanged();
        return this;
      }
      /**
       * <code>string name = 1;</code>
       * @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();
  }
  checkByteStringIsUtf8(value);
        
        name_ = value;
        onChanged();
        return this;
      }

      private com.google.protobuf.LazyStringList functions_ = com.google.protobuf.LazyStringArrayList.EMPTY;
      private void ensureFunctionsIsMutable() {
        if (!((bitField0_ & 0x00000001) != 0)) {
          functions_ = new com.google.protobuf.LazyStringArrayList(functions_);
          bitField0_ |= 0x00000001;
         }
      }
      /**
       * <code>repeated string functions = 2;</code>
       * @return A list containing the functions.
       */
      public com.google.protobuf.ProtocolStringList
          getFunctionsList() {
        return functions_.getUnmodifiableView();
      }
      /**
       * <code>repeated string functions = 2;</code>
       * @return The count of functions.
       */
      public int getFunctionsCount() {
        return functions_.size();
      }
      /**
       * <code>repeated string functions = 2;</code>
       * @param index The index of the element to return.
       * @return The functions at the given index.
       */
      public java.lang.String getFunctions(int index) {
        return functions_.get(index);
      }
      /**
       * <code>repeated string functions = 2;</code>
       * @param index The index of the value to return.
       * @return The bytes of the functions at the given index.
       */
      public com.google.protobuf.ByteString
          getFunctionsBytes(int index) {
        return functions_.getByteString(index);
      }
      /**
       * <code>repeated string functions = 2;</code>
       * @param index The index to set the value at.
       * @param value The functions to set.
       * @return This builder for chaining.
       */
      public Builder setFunctions(
          int index, java.lang.String value) {
        if (value == null) {
    throw new NullPointerException();
  }
  ensureFunctionsIsMutable();
        functions_.set(index, value);
        onChanged();
        return this;
      }
      /**
       * <code>repeated string functions = 2;</code>
       * @param value The functions to add.
       * @return This builder for chaining.
       */
      public Builder addFunctions(
          java.lang.String value) {
        if (value == null) {
    throw new NullPointerException();
  }
  ensureFunctionsIsMutable();
        functions_.add(value);
        onChanged();
        return this;
      }
      /**
       * <code>repeated string functions = 2;</code>
       * @param values The functions to add.
       * @return This builder for chaining.
       */
      public Builder addAllFunctions(
          java.lang.Iterable<java.lang.String> values) {
        ensureFunctionsIsMutable();
        com.google.protobuf.AbstractMessageLite.Builder.addAll(
            values, functions_);
        onChanged();
        return this;
      }
      /**
       * <code>repeated string functions = 2;</code>
       * @return This builder for chaining.
       */
      public Builder clearFunctions() {
        functions_ = com.google.protobuf.LazyStringArrayList.EMPTY;
        bitField0_ = (bitField0_ & ~0x00000001);
        onChanged();
        return this;
      }
      /**
       * <code>repeated string functions = 2;</code>
       * @param value The bytes of the functions to add.
       * @return This builder for chaining.
       */
      public Builder addFunctionsBytes(
          com.google.protobuf.ByteString value) {
        if (value == null) {
    throw new NullPointerException();
  }
  checkByteStringIsUtf8(value);
        ensureFunctionsIsMutable();
        functions_.add(value);
        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:DatabaseProperty)
    }

    // @@protoc_insertion_point(class_scope:DatabaseProperty)
    private static final org.apache.calcite.avatica.proto.Common.DatabaseProperty DEFAULT_INSTANCE;
    static {
      DEFAULT_INSTANCE = new org.apache.calcite.avatica.proto.Common.DatabaseProperty();
    }

    public static org.apache.calcite.avatica.proto.Common.DatabaseProperty getDefaultInstance() {
      return DEFAULT_INSTANCE;
    }

    private static final com.google.protobuf.Parser<DatabaseProperty>
        PARSER = new com.google.protobuf.AbstractParser<DatabaseProperty>() {
      @java.lang.Override
      public DatabaseProperty 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<DatabaseProperty> parser() {
      return PARSER;
    }

    @java.lang.Override
    public com.google.protobuf.Parser<DatabaseProperty> getParserForType() {
      return PARSER;
    }

    @java.lang.Override
    public org.apache.calcite.avatica.proto.Common.DatabaseProperty getDefaultInstanceForType() {
      return DEFAULT_INSTANCE;
    }

  }

  public interface WireMessageOrBuilder extends
      // @@protoc_insertion_point(interface_extends:WireMessage)
      com.google.protobuf.MessageOrBuilder {

    /**
     * <code>string name = 1;</code>
     * @return The name.
     */
    java.lang.String getName();
    /**
     * <code>string name = 1;</code>
     * @return The bytes for name.
     */
    com.google.protobuf.ByteString
        getNameBytes();

    /**
     * <code>bytes wrapped_message = 2;</code>
     * @return The wrappedMessage.
     */
    com.google.protobuf.ByteString getWrappedMessage();
  }
  /**
   * <pre>
   * Message which encapsulates another message to support a single RPC endpoint
   * </pre>
   *
   * Protobuf type {@code WireMessage}
   */
  public static final class WireMessage extends
      com.google.protobuf.GeneratedMessageV3 implements
      // @@protoc_insertion_point(message_implements:WireMessage)
      WireMessageOrBuilder {
  private static final long serialVersionUID = 0L;
    // Use WireMessage.newBuilder() to construct.
    private WireMessage(com.google.protobuf.GeneratedMessageV3.Builder<?> builder) {
      super(builder);
    }
    private WireMessage() {
      name_ = "";
      wrappedMessage_ = com.google.protobuf.ByteString.EMPTY;
    }

    @java.lang.Override
    @SuppressWarnings({"unused"})
    protected java.lang.Object newInstance(
        UnusedPrivateParameter unused) {
      return new WireMessage();
    }

    @java.lang.Override
    public final com.google.protobuf.UnknownFieldSet
    getUnknownFields() {
      return this.unknownFields;
    }
    public static final com.google.protobuf.Descriptors.Descriptor
        getDescriptor() {
      return org.apache.calcite.avatica.proto.Common.internal_static_WireMessage_descriptor;
    }

    @java.lang.Override
    protected com.google.protobuf.GeneratedMessageV3.FieldAccessorTable
        internalGetFieldAccessorTable() {
      return org.apache.calcite.avatica.proto.Common.internal_static_WireMessage_fieldAccessorTable
          .ensureFieldAccessorsInitialized(
              org.apache.calcite.avatica.proto.Common.WireMessage.class, org.apache.calcite.avatica.proto.Common.WireMessage.Builder.class);
    }

    public static final int NAME_FIELD_NUMBER = 1;
    private volatile java.lang.Object name_;
    /**
     * <code>string name = 1;</code>
     * @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();
        name_ = s;
        return s;
      }
    }
    /**
     * <code>string name = 1;</code>
     * @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 WRAPPED_MESSAGE_FIELD_NUMBER = 2;
    private com.google.protobuf.ByteString wrappedMessage_;
    /**
     * <code>bytes wrapped_message = 2;</code>
     * @return The wrappedMessage.
     */
    @java.lang.Override
    public com.google.protobuf.ByteString getWrappedMessage() {
      return wrappedMessage_;
    }

    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 (!com.google.protobuf.GeneratedMessageV3.isStringEmpty(name_)) {
        com.google.protobuf.GeneratedMessageV3.writeString(output, 1, name_);
      }
      if (!wrappedMessage_.isEmpty()) {
        output.writeBytes(2, wrappedMessage_);
      }
      getUnknownFields().writeTo(output);
    }

    @java.lang.Override
    public int getSerializedSize() {
      int size = memoizedSize;
      if (size != -1) return size;

      size = 0;
      if (!com.google.protobuf.GeneratedMessageV3.isStringEmpty(name_)) {
        size += com.google.protobuf.GeneratedMessageV3.computeStringSize(1, name_);
      }
      if (!wrappedMessage_.isEmpty()) {
        size += com.google.protobuf.CodedOutputStream
          .computeBytesSize(2, wrappedMessage_);
      }
      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 org.apache.calcite.avatica.proto.Common.WireMessage)) {
        return super.equals(obj);
      }
      org.apache.calcite.avatica.proto.Common.WireMessage other = (org.apache.calcite.avatica.proto.Common.WireMessage) obj;

      if (!getName()
          .equals(other.getName())) return false;
      if (!getWrappedMessage()
          .equals(other.getWrappedMessage())) 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();
      hash = (37 * hash) + NAME_FIELD_NUMBER;
      hash = (53 * hash) + getName().hashCode();
      hash = (37 * hash) + WRAPPED_MESSAGE_FIELD_NUMBER;
      hash = (53 * hash) + getWrappedMessage().hashCode();
      hash = (29 * hash) + getUnknownFields().hashCode();
      memoizedHashCode = hash;
      return hash;
    }

    public static org.apache.calcite.avatica.proto.Common.WireMessage parseFrom(
        java.nio.ByteBuffer data)
        throws com.google.protobuf.InvalidProtocolBufferException {
      return PARSER.parseFrom(data);
    }
    public static org.apache.calcite.avatica.proto.Common.WireMessage parseFrom(
        java.nio.ByteBuffer data,
        com.google.protobuf.ExtensionRegistryLite extensionRegistry)
        throws com.google.protobuf.InvalidProtocolBufferException {
      return PARSER.parseFrom(data, extensionRegistry);
    }
    public static org.apache.calcite.avatica.proto.Common.WireMessage parseFrom(
        com.google.protobuf.ByteString data)
        throws com.google.protobuf.InvalidProtocolBufferException {
      return PARSER.parseFrom(data);
    }
    public static org.apache.calcite.avatica.proto.Common.WireMessage parseFrom(
        com.google.protobuf.ByteString data,
        com.google.protobuf.ExtensionRegistryLite extensionRegistry)
        throws com.google.protobuf.InvalidProtocolBufferException {
      return PARSER.parseFrom(data, extensionRegistry);
    }
    public static org.apache.calcite.avatica.proto.Common.WireMessage parseFrom(byte[] data)
        throws com.google.protobuf.InvalidProtocolBufferException {
      return PARSER.parseFrom(data);
    }
    public static org.apache.calcite.avatica.proto.Common.WireMessage parseFrom(
        byte[] data,
        com.google.protobuf.ExtensionRegistryLite extensionRegistry)
        throws com.google.protobuf.InvalidProtocolBufferException {
      return PARSER.parseFrom(data, extensionRegistry);
    }
    public static org.apache.calcite.avatica.proto.Common.WireMessage parseFrom(java.io.InputStream input)
        throws java.io.IOException {
      return com.google.protobuf.GeneratedMessageV3
          .parseWithIOException(PARSER, input);
    }
    public static org.apache.calcite.avatica.proto.Common.WireMessage 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 org.apache.calcite.avatica.proto.Common.WireMessage parseDelimitedFrom(java.io.InputStream input)
        throws java.io.IOException {
      return com.google.protobuf.GeneratedMessageV3
          .parseDelimitedWithIOException(PARSER, input);
    }
    public static org.apache.calcite.avatica.proto.Common.WireMessage 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 org.apache.calcite.avatica.proto.Common.WireMessage parseFrom(
        com.google.protobuf.CodedInputStream input)
        throws java.io.IOException {
      return com.google.protobuf.GeneratedMessageV3
          .parseWithIOException(PARSER, input);
    }
    public static org.apache.calcite.avatica.proto.Common.WireMessage 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(org.apache.calcite.avatica.proto.Common.WireMessage 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;
    }
    /**
     * <pre>
     * Message which encapsulates another message to support a single RPC endpoint
     * </pre>
     *
     * Protobuf type {@code WireMessage}
     */
    public static final class Builder extends
        com.google.protobuf.GeneratedMessageV3.Builder<Builder> implements
        // @@protoc_insertion_point(builder_implements:WireMessage)
        org.apache.calcite.avatica.proto.Common.WireMessageOrBuilder {
      public static final com.google.protobuf.Descriptors.Descriptor
          getDescriptor() {
        return org.apache.calcite.avatica.proto.Common.internal_static_WireMessage_descriptor;
      }

      @java.lang.Override
      protected com.google.protobuf.GeneratedMessageV3.FieldAccessorTable
          internalGetFieldAccessorTable() {
        return org.apache.calcite.avatica.proto.Common.internal_static_WireMessage_fieldAccessorTable
            .ensureFieldAccessorsInitialized(
                org.apache.calcite.avatica.proto.Common.WireMessage.class, org.apache.calcite.avatica.proto.Common.WireMessage.Builder.class);
      }

      // Construct using org.apache.calcite.avatica.proto.Common.WireMessage.newBuilder()
      private Builder() {

      }

      private Builder(
          com.google.protobuf.GeneratedMessageV3.BuilderParent parent) {
        super(parent);

      }
      @java.lang.Override
      public Builder clear() {
        super.clear();
        name_ = "";

        wrappedMessage_ = com.google.protobuf.ByteString.EMPTY;

        return this;
      }

      @java.lang.Override
      public com.google.protobuf.Descriptors.Descriptor
          getDescriptorForType() {
        return org.apache.calcite.avatica.proto.Common.internal_static_WireMessage_descriptor;
      }

      @java.lang.Override
      public org.apache.calcite.avatica.proto.Common.WireMessage getDefaultInstanceForType() {
        return org.apache.calcite.avatica.proto.Common.WireMessage.getDefaultInstance();
      }

      @java.lang.Override
      public org.apache.calcite.avatica.proto.Common.WireMessage build() {
        org.apache.calcite.avatica.proto.Common.WireMessage result = buildPartial();
        if (!result.isInitialized()) {
          throw newUninitializedMessageException(result);
        }
        return result;
      }

      @java.lang.Override
      public org.apache.calcite.avatica.proto.Common.WireMessage buildPartial() {
        org.apache.calcite.avatica.proto.Common.WireMessage result = new org.apache.calcite.avatica.proto.Common.WireMessage(this);
        result.name_ = name_;
        result.wrappedMessage_ = wrappedMessage_;
        onBuilt();
        return result;
      }

      @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 org.apache.calcite.avatica.proto.Common.WireMessage) {
          return mergeFrom((org.apache.calcite.avatica.proto.Common.WireMessage)other);
        } else {
          super.mergeFrom(other);
          return this;
        }
      }

      public Builder mergeFrom(org.apache.calcite.avatica.proto.Common.WireMessage other) {
        if (other == org.apache.calcite.avatica.proto.Common.WireMessage.getDefaultInstance()) return this;
        if (!other.getName().isEmpty()) {
          name_ = other.name_;
          onChanged();
        }
        if (other.getWrappedMessage() != com.google.protobuf.ByteString.EMPTY) {
          setWrappedMessage(other.getWrappedMessage());
        }
        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.readStringRequireUtf8();

                break;
              } // case 10
              case 18: {
                wrappedMessage_ = input.readBytes();

                break;
              } // case 18
              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 java.lang.Object name_ = "";
      /**
       * <code>string name = 1;</code>
       * @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();
          name_ = s;
          return s;
        } else {
          return (java.lang.String) ref;
        }
      }
      /**
       * <code>string name = 1;</code>
       * @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;
        }
      }
      /**
       * <code>string name = 1;</code>
       * @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;
        onChanged();
        return this;
      }
      /**
       * <code>string name = 1;</code>
       * @return This builder for chaining.
       */
      public Builder clearName() {
        
        name_ = getDefaultInstance().getName();
        onChanged();
        return this;
      }
      /**
       * <code>string name = 1;</code>
       * @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();
  }
  checkByteStringIsUtf8(value);
        
        name_ = value;
        onChanged();
        return this;
      }

      private com.google.protobuf.ByteString wrappedMessage_ = com.google.protobuf.ByteString.EMPTY;
      /**
       * <code>bytes wrapped_message = 2;</code>
       * @return The wrappedMessage.
       */
      @java.lang.Override
      public com.google.protobuf.ByteString getWrappedMessage() {
        return wrappedMessage_;
      }
      /**
       * <code>bytes wrapped_message = 2;</code>
       * @param value The wrappedMessage to set.
       * @return This builder for chaining.
       */
      public Builder setWrappedMessage(com.google.protobuf.ByteString value) {
        if (value == null) {
    throw new NullPointerException();
  }
  
        wrappedMessage_ = value;
        onChanged();
        return this;
      }
      /**
       * <code>bytes wrapped_message = 2;</code>
       * @return This builder for chaining.
       */
      public Builder clearWrappedMessage() {
        
        wrappedMessage_ = getDefaultInstance().getWrappedMessage();
        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:WireMessage)
    }

    // @@protoc_insertion_point(class_scope:WireMessage)
    private static final org.apache.calcite.avatica.proto.Common.WireMessage DEFAULT_INSTANCE;
    static {
      DEFAULT_INSTANCE = new org.apache.calcite.avatica.proto.Common.WireMessage();
    }

    public static org.apache.calcite.avatica.proto.Common.WireMessage getDefaultInstance() {
      return DEFAULT_INSTANCE;
    }

    private static final com.google.protobuf.Parser<WireMessage>
        PARSER = new com.google.protobuf.AbstractParser<WireMessage>() {
      @java.lang.Override
      public WireMessage 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<WireMessage> parser() {
      return PARSER;
    }

    @java.lang.Override
    public com.google.protobuf.Parser<WireMessage> getParserForType() {
      return PARSER;
    }

    @java.lang.Override
    public org.apache.calcite.avatica.proto.Common.WireMessage getDefaultInstanceForType() {
      return DEFAULT_INSTANCE;
    }

  }

  public interface ColumnValueOrBuilder extends
      // @@protoc_insertion_point(interface_extends:ColumnValue)
      com.google.protobuf.MessageOrBuilder {

    /**
     * <pre>
     * deprecated, use array_value or scalar_value
     * </pre>
     *
     * <code>repeated .TypedValue value = 1;</code>
     */
    java.util.List<org.apache.calcite.avatica.proto.Common.TypedValue> 
        getValueList();
    /**
     * <pre>
     * deprecated, use array_value or scalar_value
     * </pre>
     *
     * <code>repeated .TypedValue value = 1;</code>
     */
    org.apache.calcite.avatica.proto.Common.TypedValue getValue(int index);
    /**
     * <pre>
     * deprecated, use array_value or scalar_value
     * </pre>
     *
     * <code>repeated .TypedValue value = 1;</code>
     */
    int getValueCount();
    /**
     * <pre>
     * deprecated, use array_value or scalar_value
     * </pre>
     *
     * <code>repeated .TypedValue value = 1;</code>
     */
    java.util.List<? extends org.apache.calcite.avatica.proto.Common.TypedValueOrBuilder> 
        getValueOrBuilderList();
    /**
     * <pre>
     * deprecated, use array_value or scalar_value
     * </pre>
     *
     * <code>repeated .TypedValue value = 1;</code>
     */
    org.apache.calcite.avatica.proto.Common.TypedValueOrBuilder getValueOrBuilder(
        int index);

    /**
     * <code>repeated .TypedValue array_value = 2;</code>
     */
    java.util.List<org.apache.calcite.avatica.proto.Common.TypedValue> 
        getArrayValueList();
    /**
     * <code>repeated .TypedValue array_value = 2;</code>
     */
    org.apache.calcite.avatica.proto.Common.TypedValue getArrayValue(int index);
    /**
     * <code>repeated .TypedValue array_value = 2;</code>
     */
    int getArrayValueCount();
    /**
     * <code>repeated .TypedValue array_value = 2;</code>
     */
    java.util.List<? extends org.apache.calcite.avatica.proto.Common.TypedValueOrBuilder> 
        getArrayValueOrBuilderList();
    /**
     * <code>repeated .TypedValue array_value = 2;</code>
     */
    org.apache.calcite.avatica.proto.Common.TypedValueOrBuilder getArrayValueOrBuilder(
        int index);

    /**
     * <pre>
     * Is an array value set?
     * </pre>
     *
     * <code>bool has_array_value = 3;</code>
     * @return The hasArrayValue.
     */
    boolean getHasArrayValue();

    /**
     * <code>.TypedValue scalar_value = 4;</code>
     * @return Whether the scalarValue field is set.
     */
    boolean hasScalarValue();
    /**
     * <code>.TypedValue scalar_value = 4;</code>
     * @return The scalarValue.
     */
    org.apache.calcite.avatica.proto.Common.TypedValue getScalarValue();
    /**
     * <code>.TypedValue scalar_value = 4;</code>
     */
    org.apache.calcite.avatica.proto.Common.TypedValueOrBuilder getScalarValueOrBuilder();
  }
  /**
   * <pre>
   * A value might be a TypedValue or an Array of TypedValue's
   * </pre>
   *
   * Protobuf type {@code ColumnValue}
   */
  public static final class ColumnValue extends
      com.google.protobuf.GeneratedMessageV3 implements
      // @@protoc_insertion_point(message_implements:ColumnValue)
      ColumnValueOrBuilder {
  private static final long serialVersionUID = 0L;
    // Use ColumnValue.newBuilder() to construct.
    private ColumnValue(com.google.protobuf.GeneratedMessageV3.Builder<?> builder) {
      super(builder);
    }
    private ColumnValue() {
      value_ = java.util.Collections.emptyList();
      arrayValue_ = java.util.Collections.emptyList();
    }

    @java.lang.Override
    @SuppressWarnings({"unused"})
    protected java.lang.Object newInstance(
        UnusedPrivateParameter unused) {
      return new ColumnValue();
    }

    @java.lang.Override
    public final com.google.protobuf.UnknownFieldSet
    getUnknownFields() {
      return this.unknownFields;
    }
    public static final com.google.protobuf.Descriptors.Descriptor
        getDescriptor() {
      return org.apache.calcite.avatica.proto.Common.internal_static_ColumnValue_descriptor;
    }

    @java.lang.Override
    protected com.google.protobuf.GeneratedMessageV3.FieldAccessorTable
        internalGetFieldAccessorTable() {
      return org.apache.calcite.avatica.proto.Common.internal_static_ColumnValue_fieldAccessorTable
          .ensureFieldAccessorsInitialized(
              org.apache.calcite.avatica.proto.Common.ColumnValue.class, org.apache.calcite.avatica.proto.Common.ColumnValue.Builder.class);
    }

    public static final int VALUE_FIELD_NUMBER = 1;
    private java.util.List<org.apache.calcite.avatica.proto.Common.TypedValue> value_;
    /**
     * <pre>
     * deprecated, use array_value or scalar_value
     * </pre>
     *
     * <code>repeated .TypedValue value = 1;</code>
     */
    @java.lang.Override
    public java.util.List<org.apache.calcite.avatica.proto.Common.TypedValue> getValueList() {
      return value_;
    }
    /**
     * <pre>
     * deprecated, use array_value or scalar_value
     * </pre>
     *
     * <code>repeated .TypedValue value = 1;</code>
     */
    @java.lang.Override
    public java.util.List<? extends org.apache.calcite.avatica.proto.Common.TypedValueOrBuilder> 
        getValueOrBuilderList() {
      return value_;
    }
    /**
     * <pre>
     * deprecated, use array_value or scalar_value
     * </pre>
     *
     * <code>repeated .TypedValue value = 1;</code>
     */
    @java.lang.Override
    public int getValueCount() {
      return value_.size();
    }
    /**
     * <pre>
     * deprecated, use array_value or scalar_value
     * </pre>
     *
     * <code>repeated .TypedValue value = 1;</code>
     */
    @java.lang.Override
    public org.apache.calcite.avatica.proto.Common.TypedValue getValue(int index) {
      return value_.get(index);
    }
    /**
     * <pre>
     * deprecated, use array_value or scalar_value
     * </pre>
     *
     * <code>repeated .TypedValue value = 1;</code>
     */
    @java.lang.Override
    public org.apache.calcite.avatica.proto.Common.TypedValueOrBuilder getValueOrBuilder(
        int index) {
      return value_.get(index);
    }

    public static final int ARRAY_VALUE_FIELD_NUMBER = 2;
    private java.util.List<org.apache.calcite.avatica.proto.Common.TypedValue> arrayValue_;
    /**
     * <code>repeated .TypedValue array_value = 2;</code>
     */
    @java.lang.Override
    public java.util.List<org.apache.calcite.avatica.proto.Common.TypedValue> getArrayValueList() {
      return arrayValue_;
    }
    /**
     * <code>repeated .TypedValue array_value = 2;</code>
     */
    @java.lang.Override
    public java.util.List<? extends org.apache.calcite.avatica.proto.Common.TypedValueOrBuilder> 
        getArrayValueOrBuilderList() {
      return arrayValue_;
    }
    /**
     * <code>repeated .TypedValue array_value = 2;</code>
     */
    @java.lang.Override
    public int getArrayValueCount() {
      return arrayValue_.size();
    }
    /**
     * <code>repeated .TypedValue array_value = 2;</code>
     */
    @java.lang.Override
    public org.apache.calcite.avatica.proto.Common.TypedValue getArrayValue(int index) {
      return arrayValue_.get(index);
    }
    /**
     * <code>repeated .TypedValue array_value = 2;</code>
     */
    @java.lang.Override
    public org.apache.calcite.avatica.proto.Common.TypedValueOrBuilder getArrayValueOrBuilder(
        int index) {
      return arrayValue_.get(index);
    }

    public static final int HAS_ARRAY_VALUE_FIELD_NUMBER = 3;
    private boolean hasArrayValue_;
    /**
     * <pre>
     * Is an array value set?
     * </pre>
     *
     * <code>bool has_array_value = 3;</code>
     * @return The hasArrayValue.
     */
    @java.lang.Override
    public boolean getHasArrayValue() {
      return hasArrayValue_;
    }

    public static final int SCALAR_VALUE_FIELD_NUMBER = 4;
    private org.apache.calcite.avatica.proto.Common.TypedValue scalarValue_;
    /**
     * <code>.TypedValue scalar_value = 4;</code>
     * @return Whether the scalarValue field is set.
     */
    @java.lang.Override
    public boolean hasScalarValue() {
      return scalarValue_ != null;
    }
    /**
     * <code>.TypedValue scalar_value = 4;</code>
     * @return The scalarValue.
     */
    @java.lang.Override
    public org.apache.calcite.avatica.proto.Common.TypedValue getScalarValue() {
      return scalarValue_ == null ? org.apache.calcite.avatica.proto.Common.TypedValue.getDefaultInstance() : scalarValue_;
    }
    /**
     * <code>.TypedValue scalar_value = 4;</code>
     */
    @java.lang.Override
    public org.apache.calcite.avatica.proto.Common.TypedValueOrBuilder getScalarValueOrBuilder() {
      return getScalarValue();
    }

    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 {
      for (int i = 0; i < value_.size(); i++) {
        output.writeMessage(1, value_.get(i));
      }
      for (int i = 0; i < arrayValue_.size(); i++) {
        output.writeMessage(2, arrayValue_.get(i));
      }
      if (hasArrayValue_ != false) {
        output.writeBool(3, hasArrayValue_);
      }
      if (scalarValue_ != null) {
        output.writeMessage(4, getScalarValue());
      }
      getUnknownFields().writeTo(output);
    }

    @java.lang.Override
    public int getSerializedSize() {
      int size = memoizedSize;
      if (size != -1) return size;

      size = 0;
      for (int i = 0; i < value_.size(); i++) {
        size += com.google.protobuf.CodedOutputStream
          .computeMessageSize(1, value_.get(i));
      }
      for (int i = 0; i < arrayValue_.size(); i++) {
        size += com.google.protobuf.CodedOutputStream
          .computeMessageSize(2, arrayValue_.get(i));
      }
      if (hasArrayValue_ != false) {
        size += com.google.protobuf.CodedOutputStream
          .computeBoolSize(3, hasArrayValue_);
      }
      if (scalarValue_ != null) {
        size += com.google.protobuf.CodedOutputStream
          .computeMessageSize(4, getScalarValue());
      }
      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 org.apache.calcite.avatica.proto.Common.ColumnValue)) {
        return super.equals(obj);
      }
      org.apache.calcite.avatica.proto.Common.ColumnValue other = (org.apache.calcite.avatica.proto.Common.ColumnValue) obj;

      if (!getValueList()
          .equals(other.getValueList())) return false;
      if (!getArrayValueList()
          .equals(other.getArrayValueList())) return false;
      if (getHasArrayValue()
          != other.getHasArrayValue()) return false;
      if (hasScalarValue() != other.hasScalarValue()) return false;
      if (hasScalarValue()) {
        if (!getScalarValue()
            .equals(other.getScalarValue())) 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 (getValueCount() > 0) {
        hash = (37 * hash) + VALUE_FIELD_NUMBER;
        hash = (53 * hash) + getValueList().hashCode();
      }
      if (getArrayValueCount() > 0) {
        hash = (37 * hash) + ARRAY_VALUE_FIELD_NUMBER;
        hash = (53 * hash) + getArrayValueList().hashCode();
      }
      hash = (37 * hash) + HAS_ARRAY_VALUE_FIELD_NUMBER;
      hash = (53 * hash) + com.google.protobuf.Internal.hashBoolean(
          getHasArrayValue());
      if (hasScalarValue()) {
        hash = (37 * hash) + SCALAR_VALUE_FIELD_NUMBER;
        hash = (53 * hash) + getScalarValue().hashCode();
      }
      hash = (29 * hash) + getUnknownFields().hashCode();
      memoizedHashCode = hash;
      return hash;
    }

    public static org.apache.calcite.avatica.proto.Common.ColumnValue parseFrom(
        java.nio.ByteBuffer data)
        throws com.google.protobuf.InvalidProtocolBufferException {
      return PARSER.parseFrom(data);
    }
    public static org.apache.calcite.avatica.proto.Common.ColumnValue parseFrom(
        java.nio.ByteBuffer data,
        com.google.protobuf.ExtensionRegistryLite extensionRegistry)
        throws com.google.protobuf.InvalidProtocolBufferException {
      return PARSER.parseFrom(data, extensionRegistry);
    }
    public static org.apache.calcite.avatica.proto.Common.ColumnValue parseFrom(
        com.google.protobuf.ByteString data)
        throws com.google.protobuf.InvalidProtocolBufferException {
      return PARSER.parseFrom(data);
    }
    public static org.apache.calcite.avatica.proto.Common.ColumnValue parseFrom(
        com.google.protobuf.ByteString data,
        com.google.protobuf.ExtensionRegistryLite extensionRegistry)
        throws com.google.protobuf.InvalidProtocolBufferException {
      return PARSER.parseFrom(data, extensionRegistry);
    }
    public static org.apache.calcite.avatica.proto.Common.ColumnValue parseFrom(byte[] data)
        throws com.google.protobuf.InvalidProtocolBufferException {
      return PARSER.parseFrom(data);
    }
    public static org.apache.calcite.avatica.proto.Common.ColumnValue parseFrom(
        byte[] data,
        com.google.protobuf.ExtensionRegistryLite extensionRegistry)
        throws com.google.protobuf.InvalidProtocolBufferException {
      return PARSER.parseFrom(data, extensionRegistry);
    }
    public static org.apache.calcite.avatica.proto.Common.ColumnValue parseFrom(java.io.InputStream input)
        throws java.io.IOException {
      return com.google.protobuf.GeneratedMessageV3
          .parseWithIOException(PARSER, input);
    }
    public static org.apache.calcite.avatica.proto.Common.ColumnValue 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 org.apache.calcite.avatica.proto.Common.ColumnValue parseDelimitedFrom(java.io.InputStream input)
        throws java.io.IOException {
      return com.google.protobuf.GeneratedMessageV3
          .parseDelimitedWithIOException(PARSER, input);
    }
    public static org.apache.calcite.avatica.proto.Common.ColumnValue 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 org.apache.calcite.avatica.proto.Common.ColumnValue parseFrom(
        com.google.protobuf.CodedInputStream input)
        throws java.io.IOException {
      return com.google.protobuf.GeneratedMessageV3
          .parseWithIOException(PARSER, input);
    }
    public static org.apache.calcite.avatica.proto.Common.ColumnValue 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(org.apache.calcite.avatica.proto.Common.ColumnValue 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;
    }
    /**
     * <pre>
     * A value might be a TypedValue or an Array of TypedValue's
     * </pre>
     *
     * Protobuf type {@code ColumnValue}
     */
    public static final class Builder extends
        com.google.protobuf.GeneratedMessageV3.Builder<Builder> implements
        // @@protoc_insertion_point(builder_implements:ColumnValue)
        org.apache.calcite.avatica.proto.Common.ColumnValueOrBuilder {
      public static final com.google.protobuf.Descriptors.Descriptor
          getDescriptor() {
        return org.apache.calcite.avatica.proto.Common.internal_static_ColumnValue_descriptor;
      }

      @java.lang.Override
      protected com.google.protobuf.GeneratedMessageV3.FieldAccessorTable
          internalGetFieldAccessorTable() {
        return org.apache.calcite.avatica.proto.Common.internal_static_ColumnValue_fieldAccessorTable
            .ensureFieldAccessorsInitialized(
                org.apache.calcite.avatica.proto.Common.ColumnValue.class, org.apache.calcite.avatica.proto.Common.ColumnValue.Builder.class);
      }

      // Construct using org.apache.calcite.avatica.proto.Common.ColumnValue.newBuilder()
      private Builder() {

      }

      private Builder(
          com.google.protobuf.GeneratedMessageV3.BuilderParent parent) {
        super(parent);

      }
      @java.lang.Override
      public Builder clear() {
        super.clear();
        if (valueBuilder_ == null) {
          value_ = java.util.Collections.emptyList();
        } else {
          value_ = null;
          valueBuilder_.clear();
        }
        bitField0_ = (bitField0_ & ~0x00000001);
        if (arrayValueBuilder_ == null) {
          arrayValue_ = java.util.Collections.emptyList();
        } else {
          arrayValue_ = null;
          arrayValueBuilder_.clear();
        }
        bitField0_ = (bitField0_ & ~0x00000002);
        hasArrayValue_ = false;

        if (scalarValueBuilder_ == null) {
          scalarValue_ = null;
        } else {
          scalarValue_ = null;
          scalarValueBuilder_ = null;
        }
        return this;
      }

      @java.lang.Override
      public com.google.protobuf.Descriptors.Descriptor
          getDescriptorForType() {
        return org.apache.calcite.avatica.proto.Common.internal_static_ColumnValue_descriptor;
      }

      @java.lang.Override
      public org.apache.calcite.avatica.proto.Common.ColumnValue getDefaultInstanceForType() {
        return org.apache.calcite.avatica.proto.Common.ColumnValue.getDefaultInstance();
      }

      @java.lang.Override
      public org.apache.calcite.avatica.proto.Common.ColumnValue build() {
        org.apache.calcite.avatica.proto.Common.ColumnValue result = buildPartial();
        if (!result.isInitialized()) {
          throw newUninitializedMessageException(result);
        }
        return result;
      }

      @java.lang.Override
      public org.apache.calcite.avatica.proto.Common.ColumnValue buildPartial() {
        org.apache.calcite.avatica.proto.Common.ColumnValue result = new org.apache.calcite.avatica.proto.Common.ColumnValue(this);
        int from_bitField0_ = bitField0_;
        if (valueBuilder_ == null) {
          if (((bitField0_ & 0x00000001) != 0)) {
            value_ = java.util.Collections.unmodifiableList(value_);
            bitField0_ = (bitField0_ & ~0x00000001);
          }
          result.value_ = value_;
        } else {
          result.value_ = valueBuilder_.build();
        }
        if (arrayValueBuilder_ == null) {
          if (((bitField0_ & 0x00000002) != 0)) {
            arrayValue_ = java.util.Collections.unmodifiableList(arrayValue_);
            bitField0_ = (bitField0_ & ~0x00000002);
          }
          result.arrayValue_ = arrayValue_;
        } else {
          result.arrayValue_ = arrayValueBuilder_.build();
        }
        result.hasArrayValue_ = hasArrayValue_;
        if (scalarValueBuilder_ == null) {
          result.scalarValue_ = scalarValue_;
        } else {
          result.scalarValue_ = scalarValueBuilder_.build();
        }
        onBuilt();
        return result;
      }

      @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 org.apache.calcite.avatica.proto.Common.ColumnValue) {
          return mergeFrom((org.apache.calcite.avatica.proto.Common.ColumnValue)other);
        } else {
          super.mergeFrom(other);
          return this;
        }
      }

      public Builder mergeFrom(org.apache.calcite.avatica.proto.Common.ColumnValue other) {
        if (other == org.apache.calcite.avatica.proto.Common.ColumnValue.getDefaultInstance()) return this;
        if (valueBuilder_ == null) {
          if (!other.value_.isEmpty()) {
            if (value_.isEmpty()) {
              value_ = other.value_;
              bitField0_ = (bitField0_ & ~0x00000001);
            } else {
              ensureValueIsMutable();
              value_.addAll(other.value_);
            }
            onChanged();
          }
        } else {
          if (!other.value_.isEmpty()) {
            if (valueBuilder_.isEmpty()) {
              valueBuilder_.dispose();
              valueBuilder_ = null;
              value_ = other.value_;
              bitField0_ = (bitField0_ & ~0x00000001);
              valueBuilder_ = 
                com.google.protobuf.GeneratedMessageV3.alwaysUseFieldBuilders ?
                   getValueFieldBuilder() : null;
            } else {
              valueBuilder_.addAllMessages(other.value_);
            }
          }
        }
        if (arrayValueBuilder_ == null) {
          if (!other.arrayValue_.isEmpty()) {
            if (arrayValue_.isEmpty()) {
              arrayValue_ = other.arrayValue_;
              bitField0_ = (bitField0_ & ~0x00000002);
            } else {
              ensureArrayValueIsMutable();
              arrayValue_.addAll(other.arrayValue_);
            }
            onChanged();
          }
        } else {
          if (!other.arrayValue_.isEmpty()) {
            if (arrayValueBuilder_.isEmpty()) {
              arrayValueBuilder_.dispose();
              arrayValueBuilder_ = null;
              arrayValue_ = other.arrayValue_;
              bitField0_ = (bitField0_ & ~0x00000002);
              arrayValueBuilder_ = 
                com.google.protobuf.GeneratedMessageV3.alwaysUseFieldBuilders ?
                   getArrayValueFieldBuilder() : null;
            } else {
              arrayValueBuilder_.addAllMessages(other.arrayValue_);
            }
          }
        }
        if (other.getHasArrayValue() != false) {
          setHasArrayValue(other.getHasArrayValue());
        }
        if (other.hasScalarValue()) {
          mergeScalarValue(other.getScalarValue());
        }
        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: {
                org.apache.calcite.avatica.proto.Common.TypedValue m =
                    input.readMessage(
                        org.apache.calcite.avatica.proto.Common.TypedValue.parser(),
                        extensionRegistry);
                if (valueBuilder_ == null) {
                  ensureValueIsMutable();
                  value_.add(m);
                } else {
                  valueBuilder_.addMessage(m);
                }
                break;
              } // case 10
              case 18: {
                org.apache.calcite.avatica.proto.Common.TypedValue m =
                    input.readMessage(
                        org.apache.calcite.avatica.proto.Common.TypedValue.parser(),
                        extensionRegistry);
                if (arrayValueBuilder_ == null) {
                  ensureArrayValueIsMutable();
                  arrayValue_.add(m);
                } else {
                  arrayValueBuilder_.addMessage(m);
                }
                break;
              } // case 18
              case 24: {
                hasArrayValue_ = input.readBool();

                break;
              } // case 24
              case 34: {
                input.readMessage(
                    getScalarValueFieldBuilder().getBuilder(),
                    extensionRegistry);

                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 java.util.List<org.apache.calcite.avatica.proto.Common.TypedValue> value_ =
        java.util.Collections.emptyList();
      private void ensureValueIsMutable() {
        if (!((bitField0_ & 0x00000001) != 0)) {
          value_ = new java.util.ArrayList<org.apache.calcite.avatica.proto.Common.TypedValue>(value_);
          bitField0_ |= 0x00000001;
         }
      }

      private com.google.protobuf.RepeatedFieldBuilderV3<
          org.apache.calcite.avatica.proto.Common.TypedValue, org.apache.calcite.avatica.proto.Common.TypedValue.Builder, org.apache.calcite.avatica.proto.Common.TypedValueOrBuilder> valueBuilder_;

      /**
       * <pre>
       * deprecated, use array_value or scalar_value
       * </pre>
       *
       * <code>repeated .TypedValue value = 1;</code>
       */
      public java.util.List<org.apache.calcite.avatica.proto.Common.TypedValue> getValueList() {
        if (valueBuilder_ == null) {
          return java.util.Collections.unmodifiableList(value_);
        } else {
          return valueBuilder_.getMessageList();
        }
      }
      /**
       * <pre>
       * deprecated, use array_value or scalar_value
       * </pre>
       *
       * <code>repeated .TypedValue value = 1;</code>
       */
      public int getValueCount() {
        if (valueBuilder_ == null) {
          return value_.size();
        } else {
          return valueBuilder_.getCount();
        }
      }
      /**
       * <pre>
       * deprecated, use array_value or scalar_value
       * </pre>
       *
       * <code>repeated .TypedValue value = 1;</code>
       */
      public org.apache.calcite.avatica.proto.Common.TypedValue getValue(int index) {
        if (valueBuilder_ == null) {
          return value_.get(index);
        } else {
          return valueBuilder_.getMessage(index);
        }
      }
      /**
       * <pre>
       * deprecated, use array_value or scalar_value
       * </pre>
       *
       * <code>repeated .TypedValue value = 1;</code>
       */
      public Builder setValue(
          int index, org.apache.calcite.avatica.proto.Common.TypedValue value) {
        if (valueBuilder_ == null) {
          if (value == null) {
            throw new NullPointerException();
          }
          ensureValueIsMutable();
          value_.set(index, value);
          onChanged();
        } else {
          valueBuilder_.setMessage(index, value);
        }
        return this;
      }
      /**
       * <pre>
       * deprecated, use array_value or scalar_value
       * </pre>
       *
       * <code>repeated .TypedValue value = 1;</code>
       */
      public Builder setValue(
          int index, org.apache.calcite.avatica.proto.Common.TypedValue.Builder builderForValue) {
        if (valueBuilder_ == null) {
          ensureValueIsMutable();
          value_.set(index, builderForValue.build());
          onChanged();
        } else {
          valueBuilder_.setMessage(index, builderForValue.build());
        }
        return this;
      }
      /**
       * <pre>
       * deprecated, use array_value or scalar_value
       * </pre>
       *
       * <code>repeated .TypedValue value = 1;</code>
       */
      public Builder addValue(org.apache.calcite.avatica.proto.Common.TypedValue value) {
        if (valueBuilder_ == null) {
          if (value == null) {
            throw new NullPointerException();
          }
          ensureValueIsMutable();
          value_.add(value);
          onChanged();
        } else {
          valueBuilder_.addMessage(value);
        }
        return this;
      }
      /**
       * <pre>
       * deprecated, use array_value or scalar_value
       * </pre>
       *
       * <code>repeated .TypedValue value = 1;</code>
       */
      public Builder addValue(
          int index, org.apache.calcite.avatica.proto.Common.TypedValue value) {
        if (valueBuilder_ == null) {
          if (value == null) {
            throw new NullPointerException();
          }
          ensureValueIsMutable();
          value_.add(index, value);
          onChanged();
        } else {
          valueBuilder_.addMessage(index, value);
        }
        return this;
      }
      /**
       * <pre>
       * deprecated, use array_value or scalar_value
       * </pre>
       *
       * <code>repeated .TypedValue value = 1;</code>
       */
      public Builder addValue(
          org.apache.calcite.avatica.proto.Common.TypedValue.Builder builderForValue) {
        if (valueBuilder_ == null) {
          ensureValueIsMutable();
          value_.add(builderForValue.build());
          onChanged();
        } else {
          valueBuilder_.addMessage(builderForValue.build());
        }
        return this;
      }
      /**
       * <pre>
       * deprecated, use array_value or scalar_value
       * </pre>
       *
       * <code>repeated .TypedValue value = 1;</code>
       */
      public Builder addValue(
          int index, org.apache.calcite.avatica.proto.Common.TypedValue.Builder builderForValue) {
        if (valueBuilder_ == null) {
          ensureValueIsMutable();
          value_.add(index, builderForValue.build());
          onChanged();
        } else {
          valueBuilder_.addMessage(index, builderForValue.build());
        }
        return this;
      }
      /**
       * <pre>
       * deprecated, use array_value or scalar_value
       * </pre>
       *
       * <code>repeated .TypedValue value = 1;</code>
       */
      public Builder addAllValue(
          java.lang.Iterable<? extends org.apache.calcite.avatica.proto.Common.TypedValue> values) {
        if (valueBuilder_ == null) {
          ensureValueIsMutable();
          com.google.protobuf.AbstractMessageLite.Builder.addAll(
              values, value_);
          onChanged();
        } else {
          valueBuilder_.addAllMessages(values);
        }
        return this;
      }
      /**
       * <pre>
       * deprecated, use array_value or scalar_value
       * </pre>
       *
       * <code>repeated .TypedValue value = 1;</code>
       */
      public Builder clearValue() {
        if (valueBuilder_ == null) {
          value_ = java.util.Collections.emptyList();
          bitField0_ = (bitField0_ & ~0x00000001);
          onChanged();
        } else {
          valueBuilder_.clear();
        }
        return this;
      }
      /**
       * <pre>
       * deprecated, use array_value or scalar_value
       * </pre>
       *
       * <code>repeated .TypedValue value = 1;</code>
       */
      public Builder removeValue(int index) {
        if (valueBuilder_ == null) {
          ensureValueIsMutable();
          value_.remove(index);
          onChanged();
        } else {
          valueBuilder_.remove(index);
        }
        return this;
      }
      /**
       * <pre>
       * deprecated, use array_value or scalar_value
       * </pre>
       *
       * <code>repeated .TypedValue value = 1;</code>
       */
      public org.apache.calcite.avatica.proto.Common.TypedValue.Builder getValueBuilder(
          int index) {
        return getValueFieldBuilder().getBuilder(index);
      }
      /**
       * <pre>
       * deprecated, use array_value or scalar_value
       * </pre>
       *
       * <code>repeated .TypedValue value = 1;</code>
       */
      public org.apache.calcite.avatica.proto.Common.TypedValueOrBuilder getValueOrBuilder(
          int index) {
        if (valueBuilder_ == null) {
          return value_.get(index);  } else {
          return valueBuilder_.getMessageOrBuilder(index);
        }
      }
      /**
       * <pre>
       * deprecated, use array_value or scalar_value
       * </pre>
       *
       * <code>repeated .TypedValue value = 1;</code>
       */
      public java.util.List<? extends org.apache.calcite.avatica.proto.Common.TypedValueOrBuilder> 
           getValueOrBuilderList() {
        if (valueBuilder_ != null) {
          return valueBuilder_.getMessageOrBuilderList();
        } else {
          return java.util.Collections.unmodifiableList(value_);
        }
      }
      /**
       * <pre>
       * deprecated, use array_value or scalar_value
       * </pre>
       *
       * <code>repeated .TypedValue value = 1;</code>
       */
      public org.apache.calcite.avatica.proto.Common.TypedValue.Builder addValueBuilder() {
        return getValueFieldBuilder().addBuilder(
            org.apache.calcite.avatica.proto.Common.TypedValue.getDefaultInstance());
      }
      /**
       * <pre>
       * deprecated, use array_value or scalar_value
       * </pre>
       *
       * <code>repeated .TypedValue value = 1;</code>
       */
      public org.apache.calcite.avatica.proto.Common.TypedValue.Builder addValueBuilder(
          int index) {
        return getValueFieldBuilder().addBuilder(
            index, org.apache.calcite.avatica.proto.Common.TypedValue.getDefaultInstance());
      }
      /**
       * <pre>
       * deprecated, use array_value or scalar_value
       * </pre>
       *
       * <code>repeated .TypedValue value = 1;</code>
       */
      public java.util.List<org.apache.calcite.avatica.proto.Common.TypedValue.Builder> 
           getValueBuilderList() {
        return getValueFieldBuilder().getBuilderList();
      }
      private com.google.protobuf.RepeatedFieldBuilderV3<
          org.apache.calcite.avatica.proto.Common.TypedValue, org.apache.calcite.avatica.proto.Common.TypedValue.Builder, org.apache.calcite.avatica.proto.Common.TypedValueOrBuilder> 
          getValueFieldBuilder() {
        if (valueBuilder_ == null) {
          valueBuilder_ = new com.google.protobuf.RepeatedFieldBuilderV3<
              org.apache.calcite.avatica.proto.Common.TypedValue, org.apache.calcite.avatica.proto.Common.TypedValue.Builder, org.apache.calcite.avatica.proto.Common.TypedValueOrBuilder>(
                  value_,
                  ((bitField0_ & 0x00000001) != 0),
                  getParentForChildren(),
                  isClean());
          value_ = null;
        }
        return valueBuilder_;
      }

      private java.util.List<org.apache.calcite.avatica.proto.Common.TypedValue> arrayValue_ =
        java.util.Collections.emptyList();
      private void ensureArrayValueIsMutable() {
        if (!((bitField0_ & 0x00000002) != 0)) {
          arrayValue_ = new java.util.ArrayList<org.apache.calcite.avatica.proto.Common.TypedValue>(arrayValue_);
          bitField0_ |= 0x00000002;
         }
      }

      private com.google.protobuf.RepeatedFieldBuilderV3<
          org.apache.calcite.avatica.proto.Common.TypedValue, org.apache.calcite.avatica.proto.Common.TypedValue.Builder, org.apache.calcite.avatica.proto.Common.TypedValueOrBuilder> arrayValueBuilder_;

      /**
       * <code>repeated .TypedValue array_value = 2;</code>
       */
      public java.util.List<org.apache.calcite.avatica.proto.Common.TypedValue> getArrayValueList() {
        if (arrayValueBuilder_ == null) {
          return java.util.Collections.unmodifiableList(arrayValue_);
        } else {
          return arrayValueBuilder_.getMessageList();
        }
      }
      /**
       * <code>repeated .TypedValue array_value = 2;</code>
       */
      public int getArrayValueCount() {
        if (arrayValueBuilder_ == null) {
          return arrayValue_.size();
        } else {
          return arrayValueBuilder_.getCount();
        }
      }
      /**
       * <code>repeated .TypedValue array_value = 2;</code>
       */
      public org.apache.calcite.avatica.proto.Common.TypedValue getArrayValue(int index) {
        if (arrayValueBuilder_ == null) {
          return arrayValue_.get(index);
        } else {
          return arrayValueBuilder_.getMessage(index);
        }
      }
      /**
       * <code>repeated .TypedValue array_value = 2;</code>
       */
      public Builder setArrayValue(
          int index, org.apache.calcite.avatica.proto.Common.TypedValue value) {
        if (arrayValueBuilder_ == null) {
          if (value == null) {
            throw new NullPointerException();
          }
          ensureArrayValueIsMutable();
          arrayValue_.set(index, value);
          onChanged();
        } else {
          arrayValueBuilder_.setMessage(index, value);
        }
        return this;
      }
      /**
       * <code>repeated .TypedValue array_value = 2;</code>
       */
      public Builder setArrayValue(
          int index, org.apache.calcite.avatica.proto.Common.TypedValue.Builder builderForValue) {
        if (arrayValueBuilder_ == null) {
          ensureArrayValueIsMutable();
          arrayValue_.set(index, builderForValue.build());
          onChanged();
        } else {
          arrayValueBuilder_.setMessage(index, builderForValue.build());
        }
        return this;
      }
      /**
       * <code>repeated .TypedValue array_value = 2;</code>
       */
      public Builder addArrayValue(org.apache.calcite.avatica.proto.Common.TypedValue value) {
        if (arrayValueBuilder_ == null) {
          if (value == null) {
            throw new NullPointerException();
          }
          ensureArrayValueIsMutable();
          arrayValue_.add(value);
          onChanged();
        } else {
          arrayValueBuilder_.addMessage(value);
        }
        return this;
      }
      /**
       * <code>repeated .TypedValue array_value = 2;</code>
       */
      public Builder addArrayValue(
          int index, org.apache.calcite.avatica.proto.Common.TypedValue value) {
        if (arrayValueBuilder_ == null) {
          if (value == null) {
            throw new NullPointerException();
          }
          ensureArrayValueIsMutable();
          arrayValue_.add(index, value);
          onChanged();
        } else {
          arrayValueBuilder_.addMessage(index, value);
        }
        return this;
      }
      /**
       * <code>repeated .TypedValue array_value = 2;</code>
       */
      public Builder addArrayValue(
          org.apache.calcite.avatica.proto.Common.TypedValue.Builder builderForValue) {
        if (arrayValueBuilder_ == null) {
          ensureArrayValueIsMutable();
          arrayValue_.add(builderForValue.build());
          onChanged();
        } else {
          arrayValueBuilder_.addMessage(builderForValue.build());
        }
        return this;
      }
      /**
       * <code>repeated .TypedValue array_value = 2;</code>
       */
      public Builder addArrayValue(
          int index, org.apache.calcite.avatica.proto.Common.TypedValue.Builder builderForValue) {
        if (arrayValueBuilder_ == null) {
          ensureArrayValueIsMutable();
          arrayValue_.add(index, builderForValue.build());
          onChanged();
        } else {
          arrayValueBuilder_.addMessage(index, builderForValue.build());
        }
        return this;
      }
      /**
       * <code>repeated .TypedValue array_value = 2;</code>
       */
      public Builder addAllArrayValue(
          java.lang.Iterable<? extends org.apache.calcite.avatica.proto.Common.TypedValue> values) {
        if (arrayValueBuilder_ == null) {
          ensureArrayValueIsMutable();
          com.google.protobuf.AbstractMessageLite.Builder.addAll(
              values, arrayValue_);
          onChanged();
        } else {
          arrayValueBuilder_.addAllMessages(values);
        }
        return this;
      }
      /**
       * <code>repeated .TypedValue array_value = 2;</code>
       */
      public Builder clearArrayValue() {
        if (arrayValueBuilder_ == null) {
          arrayValue_ = java.util.Collections.emptyList();
          bitField0_ = (bitField0_ & ~0x00000002);
          onChanged();
        } else {
          arrayValueBuilder_.clear();
        }
        return this;
      }
      /**
       * <code>repeated .TypedValue array_value = 2;</code>
       */
      public Builder removeArrayValue(int index) {
        if (arrayValueBuilder_ == null) {
          ensureArrayValueIsMutable();
          arrayValue_.remove(index);
          onChanged();
        } else {
          arrayValueBuilder_.remove(index);
        }
        return this;
      }
      /**
       * <code>repeated .TypedValue array_value = 2;</code>
       */
      public org.apache.calcite.avatica.proto.Common.TypedValue.Builder getArrayValueBuilder(
          int index) {
        return getArrayValueFieldBuilder().getBuilder(index);
      }
      /**
       * <code>repeated .TypedValue array_value = 2;</code>
       */
      public org.apache.calcite.avatica.proto.Common.TypedValueOrBuilder getArrayValueOrBuilder(
          int index) {
        if (arrayValueBuilder_ == null) {
          return arrayValue_.get(index);  } else {
          return arrayValueBuilder_.getMessageOrBuilder(index);
        }
      }
      /**
       * <code>repeated .TypedValue array_value = 2;</code>
       */
      public java.util.List<? extends org.apache.calcite.avatica.proto.Common.TypedValueOrBuilder> 
           getArrayValueOrBuilderList() {
        if (arrayValueBuilder_ != null) {
          return arrayValueBuilder_.getMessageOrBuilderList();
        } else {
          return java.util.Collections.unmodifiableList(arrayValue_);
        }
      }
      /**
       * <code>repeated .TypedValue array_value = 2;</code>
       */
      public org.apache.calcite.avatica.proto.Common.TypedValue.Builder addArrayValueBuilder() {
        return getArrayValueFieldBuilder().addBuilder(
            org.apache.calcite.avatica.proto.Common.TypedValue.getDefaultInstance());
      }
      /**
       * <code>repeated .TypedValue array_value = 2;</code>
       */
      public org.apache.calcite.avatica.proto.Common.TypedValue.Builder addArrayValueBuilder(
          int index) {
        return getArrayValueFieldBuilder().addBuilder(
            index, org.apache.calcite.avatica.proto.Common.TypedValue.getDefaultInstance());
      }
      /**
       * <code>repeated .TypedValue array_value = 2;</code>
       */
      public java.util.List<org.apache.calcite.avatica.proto.Common.TypedValue.Builder> 
           getArrayValueBuilderList() {
        return getArrayValueFieldBuilder().getBuilderList();
      }
      private com.google.protobuf.RepeatedFieldBuilderV3<
          org.apache.calcite.avatica.proto.Common.TypedValue, org.apache.calcite.avatica.proto.Common.TypedValue.Builder, org.apache.calcite.avatica.proto.Common.TypedValueOrBuilder> 
          getArrayValueFieldBuilder() {
        if (arrayValueBuilder_ == null) {
          arrayValueBuilder_ = new com.google.protobuf.RepeatedFieldBuilderV3<
              org.apache.calcite.avatica.proto.Common.TypedValue, org.apache.calcite.avatica.proto.Common.TypedValue.Builder, org.apache.calcite.avatica.proto.Common.TypedValueOrBuilder>(
                  arrayValue_,
                  ((bitField0_ & 0x00000002) != 0),
                  getParentForChildren(),
                  isClean());
          arrayValue_ = null;
        }
        return arrayValueBuilder_;
      }

      private boolean hasArrayValue_ ;
      /**
       * <pre>
       * Is an array value set?
       * </pre>
       *
       * <code>bool has_array_value = 3;</code>
       * @return The hasArrayValue.
       */
      @java.lang.Override
      public boolean getHasArrayValue() {
        return hasArrayValue_;
      }
      /**
       * <pre>
       * Is an array value set?
       * </pre>
       *
       * <code>bool has_array_value = 3;</code>
       * @param value The hasArrayValue to set.
       * @return This builder for chaining.
       */
      public Builder setHasArrayValue(boolean value) {
        
        hasArrayValue_ = value;
        onChanged();
        return this;
      }
      /**
       * <pre>
       * Is an array value set?
       * </pre>
       *
       * <code>bool has_array_value = 3;</code>
       * @return This builder for chaining.
       */
      public Builder clearHasArrayValue() {
        
        hasArrayValue_ = false;
        onChanged();
        return this;
      }

      private org.apache.calcite.avatica.proto.Common.TypedValue scalarValue_;
      private com.google.protobuf.SingleFieldBuilderV3<
          org.apache.calcite.avatica.proto.Common.TypedValue, org.apache.calcite.avatica.proto.Common.TypedValue.Builder, org.apache.calcite.avatica.proto.Common.TypedValueOrBuilder> scalarValueBuilder_;
      /**
       * <code>.TypedValue scalar_value = 4;</code>
       * @return Whether the scalarValue field is set.
       */
      public boolean hasScalarValue() {
        return scalarValueBuilder_ != null || scalarValue_ != null;
      }
      /**
       * <code>.TypedValue scalar_value = 4;</code>
       * @return The scalarValue.
       */
      public org.apache.calcite.avatica.proto.Common.TypedValue getScalarValue() {
        if (scalarValueBuilder_ == null) {
          return scalarValue_ == null ? org.apache.calcite.avatica.proto.Common.TypedValue.getDefaultInstance() : scalarValue_;
        } else {
          return scalarValueBuilder_.getMessage();
        }
      }
      /**
       * <code>.TypedValue scalar_value = 4;</code>
       */
      public Builder setScalarValue(org.apache.calcite.avatica.proto.Common.TypedValue value) {
        if (scalarValueBuilder_ == null) {
          if (value == null) {
            throw new NullPointerException();
          }
          scalarValue_ = value;
          onChanged();
        } else {
          scalarValueBuilder_.setMessage(value);
        }

        return this;
      }
      /**
       * <code>.TypedValue scalar_value = 4;</code>
       */
      public Builder setScalarValue(
          org.apache.calcite.avatica.proto.Common.TypedValue.Builder builderForValue) {
        if (scalarValueBuilder_ == null) {
          scalarValue_ = builderForValue.build();
          onChanged();
        } else {
          scalarValueBuilder_.setMessage(builderForValue.build());
        }

        return this;
      }
      /**
       * <code>.TypedValue scalar_value = 4;</code>
       */
      public Builder mergeScalarValue(org.apache.calcite.avatica.proto.Common.TypedValue value) {
        if (scalarValueBuilder_ == null) {
          if (scalarValue_ != null) {
            scalarValue_ =
              org.apache.calcite.avatica.proto.Common.TypedValue.newBuilder(scalarValue_).mergeFrom(value).buildPartial();
          } else {
            scalarValue_ = value;
          }
          onChanged();
        } else {
          scalarValueBuilder_.mergeFrom(value);
        }

        return this;
      }
      /**
       * <code>.TypedValue scalar_value = 4;</code>
       */
      public Builder clearScalarValue() {
        if (scalarValueBuilder_ == null) {
          scalarValue_ = null;
          onChanged();
        } else {
          scalarValue_ = null;
          scalarValueBuilder_ = null;
        }

        return this;
      }
      /**
       * <code>.TypedValue scalar_value = 4;</code>
       */
      public org.apache.calcite.avatica.proto.Common.TypedValue.Builder getScalarValueBuilder() {
        
        onChanged();
        return getScalarValueFieldBuilder().getBuilder();
      }
      /**
       * <code>.TypedValue scalar_value = 4;</code>
       */
      public org.apache.calcite.avatica.proto.Common.TypedValueOrBuilder getScalarValueOrBuilder() {
        if (scalarValueBuilder_ != null) {
          return scalarValueBuilder_.getMessageOrBuilder();
        } else {
          return scalarValue_ == null ?
              org.apache.calcite.avatica.proto.Common.TypedValue.getDefaultInstance() : scalarValue_;
        }
      }
      /**
       * <code>.TypedValue scalar_value = 4;</code>
       */
      private com.google.protobuf.SingleFieldBuilderV3<
          org.apache.calcite.avatica.proto.Common.TypedValue, org.apache.calcite.avatica.proto.Common.TypedValue.Builder, org.apache.calcite.avatica.proto.Common.TypedValueOrBuilder> 
          getScalarValueFieldBuilder() {
        if (scalarValueBuilder_ == null) {
          scalarValueBuilder_ = new com.google.protobuf.SingleFieldBuilderV3<
              org.apache.calcite.avatica.proto.Common.TypedValue, org.apache.calcite.avatica.proto.Common.TypedValue.Builder, org.apache.calcite.avatica.proto.Common.TypedValueOrBuilder>(
                  getScalarValue(),
                  getParentForChildren(),
                  isClean());
          scalarValue_ = null;
        }
        return scalarValueBuilder_;
      }
      @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:ColumnValue)
    }

    // @@protoc_insertion_point(class_scope:ColumnValue)
    private static final org.apache.calcite.avatica.proto.Common.ColumnValue DEFAULT_INSTANCE;
    static {
      DEFAULT_INSTANCE = new org.apache.calcite.avatica.proto.Common.ColumnValue();
    }

    public static org.apache.calcite.avatica.proto.Common.ColumnValue getDefaultInstance() {
      return DEFAULT_INSTANCE;
    }

    private static final com.google.protobuf.Parser<ColumnValue>
        PARSER = new com.google.protobuf.AbstractParser<ColumnValue>() {
      @java.lang.Override
      public ColumnValue 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<ColumnValue> parser() {
      return PARSER;
    }

    @java.lang.Override
    public com.google.protobuf.Parser<ColumnValue> getParserForType() {
      return PARSER;
    }

    @java.lang.Override
    public org.apache.calcite.avatica.proto.Common.ColumnValue getDefaultInstanceForType() {
      return DEFAULT_INSTANCE;
    }

  }

  public interface TypedValueOrBuilder extends
      // @@protoc_insertion_point(interface_extends:TypedValue)
      com.google.protobuf.MessageOrBuilder {

    /**
     * <pre>
     * The actual type that was serialized in the general attribute below
     * </pre>
     *
     * <code>.Rep type = 1;</code>
     * @return The enum numeric value on the wire for type.
     */
    int getTypeValue();
    /**
     * <pre>
     * The actual type that was serialized in the general attribute below
     * </pre>
     *
     * <code>.Rep type = 1;</code>
     * @return The type.
     */
    org.apache.calcite.avatica.proto.Common.Rep getType();

    /**
     * <pre>
     * boolean
     * </pre>
     *
     * <code>bool bool_value = 2;</code>
     * @return The boolValue.
     */
    boolean getBoolValue();

    /**
     * <pre>
     * char/varchar
     * </pre>
     *
     * <code>string string_value = 3;</code>
     * @return The stringValue.
     */
    java.lang.String getStringValue();
    /**
     * <pre>
     * char/varchar
     * </pre>
     *
     * <code>string string_value = 3;</code>
     * @return The bytes for stringValue.
     */
    com.google.protobuf.ByteString
        getStringValueBytes();

    /**
     * <pre>
     * var-len encoding lets us shove anything from byte to long
     * </pre>
     *
     * <code>sint64 number_value = 4;</code>
     * @return The numberValue.
     */
    long getNumberValue();

    /**
     * <pre>
     * includes numeric types and date/time types.
     * </pre>
     *
     * <code>bytes bytes_value = 5;</code>
     * @return The bytesValue.
     */
    com.google.protobuf.ByteString getBytesValue();

    /**
     * <pre>
     * big numbers
     * </pre>
     *
     * <code>double double_value = 6;</code>
     * @return The doubleValue.
     */
    double getDoubleValue();

    /**
     * <pre>
     * a null object
     * </pre>
     *
     * <code>bool null = 7;</code>
     * @return The null.
     */
    boolean getNull();

    /**
     * <pre>
     * The Array
     * </pre>
     *
     * <code>repeated .TypedValue array_value = 8;</code>
     */
    java.util.List<org.apache.calcite.avatica.proto.Common.TypedValue> 
        getArrayValueList();
    /**
     * <pre>
     * The Array
     * </pre>
     *
     * <code>repeated .TypedValue array_value = 8;</code>
     */
    org.apache.calcite.avatica.proto.Common.TypedValue getArrayValue(int index);
    /**
     * <pre>
     * The Array
     * </pre>
     *
     * <code>repeated .TypedValue array_value = 8;</code>
     */
    int getArrayValueCount();
    /**
     * <pre>
     * The Array
     * </pre>
     *
     * <code>repeated .TypedValue array_value = 8;</code>
     */
    java.util.List<? extends org.apache.calcite.avatica.proto.Common.TypedValueOrBuilder> 
        getArrayValueOrBuilderList();
    /**
     * <pre>
     * The Array
     * </pre>
     *
     * <code>repeated .TypedValue array_value = 8;</code>
     */
    org.apache.calcite.avatica.proto.Common.TypedValueOrBuilder getArrayValueOrBuilder(
        int index);

    /**
     * <pre>
     * If an Array, the representation for the array values
     * </pre>
     *
     * <code>.Rep component_type = 9;</code>
     * @return The enum numeric value on the wire for componentType.
     */
    int getComponentTypeValue();
    /**
     * <pre>
     * If an Array, the representation for the array values
     * </pre>
     *
     * <code>.Rep component_type = 9;</code>
     * @return The componentType.
     */
    org.apache.calcite.avatica.proto.Common.Rep getComponentType();

    /**
     * <pre>
     * Differentiate between explicitly null (user-set) and implicitly null
     * </pre>
     *
     * <code>bool implicitly_null = 10;</code>
     * @return The implicitlyNull.
     */
    boolean getImplicitlyNull();
  }
  /**
   * <pre>
   * Generic wrapper to support any SQL type. Struct-like to work around no polymorphism construct.
   * </pre>
   *
   * Protobuf type {@code TypedValue}
   */
  public static final class TypedValue extends
      com.google.protobuf.GeneratedMessageV3 implements
      // @@protoc_insertion_point(message_implements:TypedValue)
      TypedValueOrBuilder {
  private static final long serialVersionUID = 0L;
    // Use TypedValue.newBuilder() to construct.
    private TypedValue(com.google.protobuf.GeneratedMessageV3.Builder<?> builder) {
      super(builder);
    }
    private TypedValue() {
      type_ = 0;
      stringValue_ = "";
      bytesValue_ = com.google.protobuf.ByteString.EMPTY;
      arrayValue_ = java.util.Collections.emptyList();
      componentType_ = 0;
    }

    @java.lang.Override
    @SuppressWarnings({"unused"})
    protected java.lang.Object newInstance(
        UnusedPrivateParameter unused) {
      return new TypedValue();
    }

    @java.lang.Override
    public final com.google.protobuf.UnknownFieldSet
    getUnknownFields() {
      return this.unknownFields;
    }
    public static final com.google.protobuf.Descriptors.Descriptor
        getDescriptor() {
      return org.apache.calcite.avatica.proto.Common.internal_static_TypedValue_descriptor;
    }

    @java.lang.Override
    protected com.google.protobuf.GeneratedMessageV3.FieldAccessorTable
        internalGetFieldAccessorTable() {
      return org.apache.calcite.avatica.proto.Common.internal_static_TypedValue_fieldAccessorTable
          .ensureFieldAccessorsInitialized(
              org.apache.calcite.avatica.proto.Common.TypedValue.class, org.apache.calcite.avatica.proto.Common.TypedValue.Builder.class);
    }

    public static final int TYPE_FIELD_NUMBER = 1;
    private int type_;
    /**
     * <pre>
     * The actual type that was serialized in the general attribute below
     * </pre>
     *
     * <code>.Rep type = 1;</code>
     * @return The enum numeric value on the wire for type.
     */
    @java.lang.Override public int getTypeValue() {
      return type_;
    }
    /**
     * <pre>
     * The actual type that was serialized in the general attribute below
     * </pre>
     *
     * <code>.Rep type = 1;</code>
     * @return The type.
     */
    @java.lang.Override public org.apache.calcite.avatica.proto.Common.Rep getType() {
      @SuppressWarnings("deprecation")
      org.apache.calcite.avatica.proto.Common.Rep result = org.apache.calcite.avatica.proto.Common.Rep.valueOf(type_);
      return result == null ? org.apache.calcite.avatica.proto.Common.Rep.UNRECOGNIZED : result;
    }

    public static final int BOOL_VALUE_FIELD_NUMBER = 2;
    private boolean boolValue_;
    /**
     * <pre>
     * boolean
     * </pre>
     *
     * <code>bool bool_value = 2;</code>
     * @return The boolValue.
     */
    @java.lang.Override
    public boolean getBoolValue() {
      return boolValue_;
    }

    public static final int STRING_VALUE_FIELD_NUMBER = 3;
    private volatile java.lang.Object stringValue_;
    /**
     * <pre>
     * char/varchar
     * </pre>
     *
     * <code>string string_value = 3;</code>
     * @return The stringValue.
     */
    @java.lang.Override
    public java.lang.String getStringValue() {
      java.lang.Object ref = stringValue_;
      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();
        stringValue_ = s;
        return s;
      }
    }
    /**
     * <pre>
     * char/varchar
     * </pre>
     *
     * <code>string string_value = 3;</code>
     * @return The bytes for stringValue.
     */
    @java.lang.Override
    public com.google.protobuf.ByteString
        getStringValueBytes() {
      java.lang.Object ref = stringValue_;
      if (ref instanceof java.lang.String) {
        com.google.protobuf.ByteString b = 
            com.google.protobuf.ByteString.copyFromUtf8(
                (java.lang.String) ref);
        stringValue_ = b;
        return b;
      } else {
        return (com.google.protobuf.ByteString) ref;
      }
    }

    public static final int NUMBER_VALUE_FIELD_NUMBER = 4;
    private long numberValue_;
    /**
     * <pre>
     * var-len encoding lets us shove anything from byte to long
     * </pre>
     *
     * <code>sint64 number_value = 4;</code>
     * @return The numberValue.
     */
    @java.lang.Override
    public long getNumberValue() {
      return numberValue_;
    }

    public static final int BYTES_VALUE_FIELD_NUMBER = 5;
    private com.google.protobuf.ByteString bytesValue_;
    /**
     * <pre>
     * includes numeric types and date/time types.
     * </pre>
     *
     * <code>bytes bytes_value = 5;</code>
     * @return The bytesValue.
     */
    @java.lang.Override
    public com.google.protobuf.ByteString getBytesValue() {
      return bytesValue_;
    }

    public static final int DOUBLE_VALUE_FIELD_NUMBER = 6;
    private double doubleValue_;
    /**
     * <pre>
     * big numbers
     * </pre>
     *
     * <code>double double_value = 6;</code>
     * @return The doubleValue.
     */
    @java.lang.Override
    public double getDoubleValue() {
      return doubleValue_;
    }

    public static final int NULL_FIELD_NUMBER = 7;
    private boolean null_;
    /**
     * <pre>
     * a null object
     * </pre>
     *
     * <code>bool null = 7;</code>
     * @return The null.
     */
    @java.lang.Override
    public boolean getNull() {
      return null_;
    }

    public static final int ARRAY_VALUE_FIELD_NUMBER = 8;
    private java.util.List<org.apache.calcite.avatica.proto.Common.TypedValue> arrayValue_;
    /**
     * <pre>
     * The Array
     * </pre>
     *
     * <code>repeated .TypedValue array_value = 8;</code>
     */
    @java.lang.Override
    public java.util.List<org.apache.calcite.avatica.proto.Common.TypedValue> getArrayValueList() {
      return arrayValue_;
    }
    /**
     * <pre>
     * The Array
     * </pre>
     *
     * <code>repeated .TypedValue array_value = 8;</code>
     */
    @java.lang.Override
    public java.util.List<? extends org.apache.calcite.avatica.proto.Common.TypedValueOrBuilder> 
        getArrayValueOrBuilderList() {
      return arrayValue_;
    }
    /**
     * <pre>
     * The Array
     * </pre>
     *
     * <code>repeated .TypedValue array_value = 8;</code>
     */
    @java.lang.Override
    public int getArrayValueCount() {
      return arrayValue_.size();
    }
    /**
     * <pre>
     * The Array
     * </pre>
     *
     * <code>repeated .TypedValue array_value = 8;</code>
     */
    @java.lang.Override
    public org.apache.calcite.avatica.proto.Common.TypedValue getArrayValue(int index) {
      return arrayValue_.get(index);
    }
    /**
     * <pre>
     * The Array
     * </pre>
     *
     * <code>repeated .TypedValue array_value = 8;</code>
     */
    @java.lang.Override
    public org.apache.calcite.avatica.proto.Common.TypedValueOrBuilder getArrayValueOrBuilder(
        int index) {
      return arrayValue_.get(index);
    }

    public static final int COMPONENT_TYPE_FIELD_NUMBER = 9;
    private int componentType_;
    /**
     * <pre>
     * If an Array, the representation for the array values
     * </pre>
     *
     * <code>.Rep component_type = 9;</code>
     * @return The enum numeric value on the wire for componentType.
     */
    @java.lang.Override public int getComponentTypeValue() {
      return componentType_;
    }
    /**
     * <pre>
     * If an Array, the representation for the array values
     * </pre>
     *
     * <code>.Rep component_type = 9;</code>
     * @return The componentType.
     */
    @java.lang.Override public org.apache.calcite.avatica.proto.Common.Rep getComponentType() {
      @SuppressWarnings("deprecation")
      org.apache.calcite.avatica.proto.Common.Rep result = org.apache.calcite.avatica.proto.Common.Rep.valueOf(componentType_);
      return result == null ? org.apache.calcite.avatica.proto.Common.Rep.UNRECOGNIZED : result;
    }

    public static final int IMPLICITLY_NULL_FIELD_NUMBER = 10;
    private boolean implicitlyNull_;
    /**
     * <pre>
     * Differentiate between explicitly null (user-set) and implicitly null
     * </pre>
     *
     * <code>bool implicitly_null = 10;</code>
     * @return The implicitlyNull.
     */
    @java.lang.Override
    public boolean getImplicitlyNull() {
      return implicitlyNull_;
    }

    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 (type_ != org.apache.calcite.avatica.proto.Common.Rep.PRIMITIVE_BOOLEAN.getNumber()) {
        output.writeEnum(1, type_);
      }
      if (boolValue_ != false) {
        output.writeBool(2, boolValue_);
      }
      if (!com.google.protobuf.GeneratedMessageV3.isStringEmpty(stringValue_)) {
        com.google.protobuf.GeneratedMessageV3.writeString(output, 3, stringValue_);
      }
      if (numberValue_ != 0L) {
        output.writeSInt64(4, numberValue_);
      }
      if (!bytesValue_.isEmpty()) {
        output.writeBytes(5, bytesValue_);
      }
      if (java.lang.Double.doubleToRawLongBits(doubleValue_) != 0) {
        output.writeDouble(6, doubleValue_);
      }
      if (null_ != false) {
        output.writeBool(7, null_);
      }
      for (int i = 0; i < arrayValue_.size(); i++) {
        output.writeMessage(8, arrayValue_.get(i));
      }
      if (componentType_ != org.apache.calcite.avatica.proto.Common.Rep.PRIMITIVE_BOOLEAN.getNumber()) {
        output.writeEnum(9, componentType_);
      }
      if (implicitlyNull_ != false) {
        output.writeBool(10, implicitlyNull_);
      }
      getUnknownFields().writeTo(output);
    }

    @java.lang.Override
    public int getSerializedSize() {
      int size = memoizedSize;
      if (size != -1) return size;

      size = 0;
      if (type_ != org.apache.calcite.avatica.proto.Common.Rep.PRIMITIVE_BOOLEAN.getNumber()) {
        size += com.google.protobuf.CodedOutputStream
          .computeEnumSize(1, type_);
      }
      if (boolValue_ != false) {
        size += com.google.protobuf.CodedOutputStream
          .computeBoolSize(2, boolValue_);
      }
      if (!com.google.protobuf.GeneratedMessageV3.isStringEmpty(stringValue_)) {
        size += com.google.protobuf.GeneratedMessageV3.computeStringSize(3, stringValue_);
      }
      if (numberValue_ != 0L) {
        size += com.google.protobuf.CodedOutputStream
          .computeSInt64Size(4, numberValue_);
      }
      if (!bytesValue_.isEmpty()) {
        size += com.google.protobuf.CodedOutputStream
          .computeBytesSize(5, bytesValue_);
      }
      if (java.lang.Double.doubleToRawLongBits(doubleValue_) != 0) {
        size += com.google.protobuf.CodedOutputStream
          .computeDoubleSize(6, doubleValue_);
      }
      if (null_ != false) {
        size += com.google.protobuf.CodedOutputStream
          .computeBoolSize(7, null_);
      }
      for (int i = 0; i < arrayValue_.size(); i++) {
        size += com.google.protobuf.CodedOutputStream
          .computeMessageSize(8, arrayValue_.get(i));
      }
      if (componentType_ != org.apache.calcite.avatica.proto.Common.Rep.PRIMITIVE_BOOLEAN.getNumber()) {
        size += com.google.protobuf.CodedOutputStream
          .computeEnumSize(9, componentType_);
      }
      if (implicitlyNull_ != false) {
        size += com.google.protobuf.CodedOutputStream
          .computeBoolSize(10, implicitlyNull_);
      }
      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 org.apache.calcite.avatica.proto.Common.TypedValue)) {
        return super.equals(obj);
      }
      org.apache.calcite.avatica.proto.Common.TypedValue other = (org.apache.calcite.avatica.proto.Common.TypedValue) obj;

      if (type_ != other.type_) return false;
      if (getBoolValue()
          != other.getBoolValue()) return false;
      if (!getStringValue()
          .equals(other.getStringValue())) return false;
      if (getNumberValue()
          != other.getNumberValue()) return false;
      if (!getBytesValue()
          .equals(other.getBytesValue())) return false;
      if (java.lang.Double.doubleToLongBits(getDoubleValue())
          != java.lang.Double.doubleToLongBits(
              other.getDoubleValue())) return false;
      if (getNull()
          != other.getNull()) return false;
      if (!getArrayValueList()
          .equals(other.getArrayValueList())) return false;
      if (componentType_ != other.componentType_) return false;
      if (getImplicitlyNull()
          != other.getImplicitlyNull()) 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();
      hash = (37 * hash) + TYPE_FIELD_NUMBER;
      hash = (53 * hash) + type_;
      hash = (37 * hash) + BOOL_VALUE_FIELD_NUMBER;
      hash = (53 * hash) + com.google.protobuf.Internal.hashBoolean(
          getBoolValue());
      hash = (37 * hash) + STRING_VALUE_FIELD_NUMBER;
      hash = (53 * hash) + getStringValue().hashCode();
      hash = (37 * hash) + NUMBER_VALUE_FIELD_NUMBER;
      hash = (53 * hash) + com.google.protobuf.Internal.hashLong(
          getNumberValue());
      hash = (37 * hash) + BYTES_VALUE_FIELD_NUMBER;
      hash = (53 * hash) + getBytesValue().hashCode();
      hash = (37 * hash) + DOUBLE_VALUE_FIELD_NUMBER;
      hash = (53 * hash) + com.google.protobuf.Internal.hashLong(
          java.lang.Double.doubleToLongBits(getDoubleValue()));
      hash = (37 * hash) + NULL_FIELD_NUMBER;
      hash = (53 * hash) + com.google.protobuf.Internal.hashBoolean(
          getNull());
      if (getArrayValueCount() > 0) {
        hash = (37 * hash) + ARRAY_VALUE_FIELD_NUMBER;
        hash = (53 * hash) + getArrayValueList().hashCode();
      }
      hash = (37 * hash) + COMPONENT_TYPE_FIELD_NUMBER;
      hash = (53 * hash) + componentType_;
      hash = (37 * hash) + IMPLICITLY_NULL_FIELD_NUMBER;
      hash = (53 * hash) + com.google.protobuf.Internal.hashBoolean(
          getImplicitlyNull());
      hash = (29 * hash) + getUnknownFields().hashCode();
      memoizedHashCode = hash;
      return hash;
    }

    public static org.apache.calcite.avatica.proto.Common.TypedValue parseFrom(
        java.nio.ByteBuffer data)
        throws com.google.protobuf.InvalidProtocolBufferException {
      return PARSER.parseFrom(data);
    }
    public static org.apache.calcite.avatica.proto.Common.TypedValue parseFrom(
        java.nio.ByteBuffer data,
        com.google.protobuf.ExtensionRegistryLite extensionRegistry)
        throws com.google.protobuf.InvalidProtocolBufferException {
      return PARSER.parseFrom(data, extensionRegistry);
    }
    public static org.apache.calcite.avatica.proto.Common.TypedValue parseFrom(
        com.google.protobuf.ByteString data)
        throws com.google.protobuf.InvalidProtocolBufferException {
      return PARSER.parseFrom(data);
    }
    public static org.apache.calcite.avatica.proto.Common.TypedValue parseFrom(
        com.google.protobuf.ByteString data,
        com.google.protobuf.ExtensionRegistryLite extensionRegistry)
        throws com.google.protobuf.InvalidProtocolBufferException {
      return PARSER.parseFrom(data, extensionRegistry);
    }
    public static org.apache.calcite.avatica.proto.Common.TypedValue parseFrom(byte[] data)
        throws com.google.protobuf.InvalidProtocolBufferException {
      return PARSER.parseFrom(data);
    }
    public static org.apache.calcite.avatica.proto.Common.TypedValue parseFrom(
        byte[] data,
        com.google.protobuf.ExtensionRegistryLite extensionRegistry)
        throws com.google.protobuf.InvalidProtocolBufferException {
      return PARSER.parseFrom(data, extensionRegistry);
    }
    public static org.apache.calcite.avatica.proto.Common.TypedValue parseFrom(java.io.InputStream input)
        throws java.io.IOException {
      return com.google.protobuf.GeneratedMessageV3
          .parseWithIOException(PARSER, input);
    }
    public static org.apache.calcite.avatica.proto.Common.TypedValue 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 org.apache.calcite.avatica.proto.Common.TypedValue parseDelimitedFrom(java.io.InputStream input)
        throws java.io.IOException {
      return com.google.protobuf.GeneratedMessageV3
          .parseDelimitedWithIOException(PARSER, input);
    }
    public static org.apache.calcite.avatica.proto.Common.TypedValue 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 org.apache.calcite.avatica.proto.Common.TypedValue parseFrom(
        com.google.protobuf.CodedInputStream input)
        throws java.io.IOException {
      return com.google.protobuf.GeneratedMessageV3
          .parseWithIOException(PARSER, input);
    }
    public static org.apache.calcite.avatica.proto.Common.TypedValue 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(org.apache.calcite.avatica.proto.Common.TypedValue 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;
    }
    /**
     * <pre>
     * Generic wrapper to support any SQL type. Struct-like to work around no polymorphism construct.
     * </pre>
     *
     * Protobuf type {@code TypedValue}
     */
    public static final class Builder extends
        com.google.protobuf.GeneratedMessageV3.Builder<Builder> implements
        // @@protoc_insertion_point(builder_implements:TypedValue)
        org.apache.calcite.avatica.proto.Common.TypedValueOrBuilder {
      public static final com.google.protobuf.Descriptors.Descriptor
          getDescriptor() {
        return org.apache.calcite.avatica.proto.Common.internal_static_TypedValue_descriptor;
      }

      @java.lang.Override
      protected com.google.protobuf.GeneratedMessageV3.FieldAccessorTable
          internalGetFieldAccessorTable() {
        return org.apache.calcite.avatica.proto.Common.internal_static_TypedValue_fieldAccessorTable
            .ensureFieldAccessorsInitialized(
                org.apache.calcite.avatica.proto.Common.TypedValue.class, org.apache.calcite.avatica.proto.Common.TypedValue.Builder.class);
      }

      // Construct using org.apache.calcite.avatica.proto.Common.TypedValue.newBuilder()
      private Builder() {

      }

      private Builder(
          com.google.protobuf.GeneratedMessageV3.BuilderParent parent) {
        super(parent);

      }
      @java.lang.Override
      public Builder clear() {
        super.clear();
        type_ = 0;

        boolValue_ = false;

        stringValue_ = "";

        numberValue_ = 0L;

        bytesValue_ = com.google.protobuf.ByteString.EMPTY;

        doubleValue_ = 0D;

        null_ = false;

        if (arrayValueBuilder_ == null) {
          arrayValue_ = java.util.Collections.emptyList();
        } else {
          arrayValue_ = null;
          arrayValueBuilder_.clear();
        }
        bitField0_ = (bitField0_ & ~0x00000001);
        componentType_ = 0;

        implicitlyNull_ = false;

        return this;
      }

      @java.lang.Override
      public com.google.protobuf.Descriptors.Descriptor
          getDescriptorForType() {
        return org.apache.calcite.avatica.proto.Common.internal_static_TypedValue_descriptor;
      }

      @java.lang.Override
      public org.apache.calcite.avatica.proto.Common.TypedValue getDefaultInstanceForType() {
        return org.apache.calcite.avatica.proto.Common.TypedValue.getDefaultInstance();
      }

      @java.lang.Override
      public org.apache.calcite.avatica.proto.Common.TypedValue build() {
        org.apache.calcite.avatica.proto.Common.TypedValue result = buildPartial();
        if (!result.isInitialized()) {
          throw newUninitializedMessageException(result);
        }
        return result;
      }

      @java.lang.Override
      public org.apache.calcite.avatica.proto.Common.TypedValue buildPartial() {
        org.apache.calcite.avatica.proto.Common.TypedValue result = new org.apache.calcite.avatica.proto.Common.TypedValue(this);
        int from_bitField0_ = bitField0_;
        result.type_ = type_;
        result.boolValue_ = boolValue_;
        result.stringValue_ = stringValue_;
        result.numberValue_ = numberValue_;
        result.bytesValue_ = bytesValue_;
        result.doubleValue_ = doubleValue_;
        result.null_ = null_;
        if (arrayValueBuilder_ == null) {
          if (((bitField0_ & 0x00000001) != 0)) {
            arrayValue_ = java.util.Collections.unmodifiableList(arrayValue_);
            bitField0_ = (bitField0_ & ~0x00000001);
          }
          result.arrayValue_ = arrayValue_;
        } else {
          result.arrayValue_ = arrayValueBuilder_.build();
        }
        result.componentType_ = componentType_;
        result.implicitlyNull_ = implicitlyNull_;
        onBuilt();
        return result;
      }

      @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 org.apache.calcite.avatica.proto.Common.TypedValue) {
          return mergeFrom((org.apache.calcite.avatica.proto.Common.TypedValue)other);
        } else {
          super.mergeFrom(other);
          return this;
        }
      }

      public Builder mergeFrom(org.apache.calcite.avatica.proto.Common.TypedValue other) {
        if (other == org.apache.calcite.avatica.proto.Common.TypedValue.getDefaultInstance()) return this;
        if (other.type_ != 0) {
          setTypeValue(other.getTypeValue());
        }
        if (other.getBoolValue() != false) {
          setBoolValue(other.getBoolValue());
        }
        if (!other.getStringValue().isEmpty()) {
          stringValue_ = other.stringValue_;
          onChanged();
        }
        if (other.getNumberValue() != 0L) {
          setNumberValue(other.getNumberValue());
        }
        if (other.getBytesValue() != com.google.protobuf.ByteString.EMPTY) {
          setBytesValue(other.getBytesValue());
        }
        if (other.getDoubleValue() != 0D) {
          setDoubleValue(other.getDoubleValue());
        }
        if (other.getNull() != false) {
          setNull(other.getNull());
        }
        if (arrayValueBuilder_ == null) {
          if (!other.arrayValue_.isEmpty()) {
            if (arrayValue_.isEmpty()) {
              arrayValue_ = other.arrayValue_;
              bitField0_ = (bitField0_ & ~0x00000001);
            } else {
              ensureArrayValueIsMutable();
              arrayValue_.addAll(other.arrayValue_);
            }
            onChanged();
          }
        } else {
          if (!other.arrayValue_.isEmpty()) {
            if (arrayValueBuilder_.isEmpty()) {
              arrayValueBuilder_.dispose();
              arrayValueBuilder_ = null;
              arrayValue_ = other.arrayValue_;
              bitField0_ = (bitField0_ & ~0x00000001);
              arrayValueBuilder_ = 
                com.google.protobuf.GeneratedMessageV3.alwaysUseFieldBuilders ?
                   getArrayValueFieldBuilder() : null;
            } else {
              arrayValueBuilder_.addAllMessages(other.arrayValue_);
            }
          }
        }
        if (other.componentType_ != 0) {
          setComponentTypeValue(other.getComponentTypeValue());
        }
        if (other.getImplicitlyNull() != false) {
          setImplicitlyNull(other.getImplicitlyNull());
        }
        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: {
                type_ = input.readEnum();

                break;
              } // case 8
              case 16: {
                boolValue_ = input.readBool();

                break;
              } // case 16
              case 26: {
                stringValue_ = input.readStringRequireUtf8();

                break;
              } // case 26
              case 32: {
                numberValue_ = input.readSInt64();

                break;
              } // case 32
              case 42: {
                bytesValue_ = input.readBytes();

                break;
              } // case 42
              case 49: {
                doubleValue_ = input.readDouble();

                break;
              } // case 49
              case 56: {
                null_ = input.readBool();

                break;
              } // case 56
              case 66: {
                org.apache.calcite.avatica.proto.Common.TypedValue m =
                    input.readMessage(
                        org.apache.calcite.avatica.proto.Common.TypedValue.parser(),
                        extensionRegistry);
                if (arrayValueBuilder_ == null) {
                  ensureArrayValueIsMutable();
                  arrayValue_.add(m);
                } else {
                  arrayValueBuilder_.addMessage(m);
                }
                break;
              } // case 66
              case 72: {
                componentType_ = input.readEnum();

                break;
              } // case 72
              case 80: {
                implicitlyNull_ = input.readBool();

                break;
              } // case 80
              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 type_ = 0;
      /**
       * <pre>
       * The actual type that was serialized in the general attribute below
       * </pre>
       *
       * <code>.Rep type = 1;</code>
       * @return The enum numeric value on the wire for type.
       */
      @java.lang.Override public int getTypeValue() {
        return type_;
      }
      /**
       * <pre>
       * The actual type that was serialized in the general attribute below
       * </pre>
       *
       * <code>.Rep type = 1;</code>
       * @param value The enum numeric value on the wire for type to set.
       * @return This builder for chaining.
       */
      public Builder setTypeValue(int value) {
        
        type_ = value;
        onChanged();
        return this;
      }
      /**
       * <pre>
       * The actual type that was serialized in the general attribute below
       * </pre>
       *
       * <code>.Rep type = 1;</code>
       * @return The type.
       */
      @java.lang.Override
      public org.apache.calcite.avatica.proto.Common.Rep getType() {
        @SuppressWarnings("deprecation")
        org.apache.calcite.avatica.proto.Common.Rep result = org.apache.calcite.avatica.proto.Common.Rep.valueOf(type_);
        return result == null ? org.apache.calcite.avatica.proto.Common.Rep.UNRECOGNIZED : result;
      }
      /**
       * <pre>
       * The actual type that was serialized in the general attribute below
       * </pre>
       *
       * <code>.Rep type = 1;</code>
       * @param value The type to set.
       * @return This builder for chaining.
       */
      public Builder setType(org.apache.calcite.avatica.proto.Common.Rep value) {
        if (value == null) {
          throw new NullPointerException();
        }
        
        type_ = value.getNumber();
        onChanged();
        return this;
      }
      /**
       * <pre>
       * The actual type that was serialized in the general attribute below
       * </pre>
       *
       * <code>.Rep type = 1;</code>
       * @return This builder for chaining.
       */
      public Builder clearType() {
        
        type_ = 0;
        onChanged();
        return this;
      }

      private boolean boolValue_ ;
      /**
       * <pre>
       * boolean
       * </pre>
       *
       * <code>bool bool_value = 2;</code>
       * @return The boolValue.
       */
      @java.lang.Override
      public boolean getBoolValue() {
        return boolValue_;
      }
      /**
       * <pre>
       * boolean
       * </pre>
       *
       * <code>bool bool_value = 2;</code>
       * @param value The boolValue to set.
       * @return This builder for chaining.
       */
      public Builder setBoolValue(boolean value) {
        
        boolValue_ = value;
        onChanged();
        return this;
      }
      /**
       * <pre>
       * boolean
       * </pre>
       *
       * <code>bool bool_value = 2;</code>
       * @return This builder for chaining.
       */
      public Builder clearBoolValue() {
        
        boolValue_ = false;
        onChanged();
        return this;
      }

      private java.lang.Object stringValue_ = "";
      /**
       * <pre>
       * char/varchar
       * </pre>
       *
       * <code>string string_value = 3;</code>
       * @return The stringValue.
       */
      public java.lang.String getStringValue() {
        java.lang.Object ref = stringValue_;
        if (!(ref instanceof java.lang.String)) {
          com.google.protobuf.ByteString bs =
              (com.google.protobuf.ByteString) ref;
          java.lang.String s = bs.toStringUtf8();
          stringValue_ = s;
          return s;
        } else {
          return (java.lang.String) ref;
        }
      }
      /**
       * <pre>
       * char/varchar
       * </pre>
       *
       * <code>string string_value = 3;</code>
       * @return The bytes for stringValue.
       */
      public com.google.protobuf.ByteString
          getStringValueBytes() {
        java.lang.Object ref = stringValue_;
        if (ref instanceof String) {
          com.google.protobuf.ByteString b = 
              com.google.protobuf.ByteString.copyFromUtf8(
                  (java.lang.String) ref);
          stringValue_ = b;
          return b;
        } else {
          return (com.google.protobuf.ByteString) ref;
        }
      }
      /**
       * <pre>
       * char/varchar
       * </pre>
       *
       * <code>string string_value = 3;</code>
       * @param value The stringValue to set.
       * @return This builder for chaining.
       */
      public Builder setStringValue(
          java.lang.String value) {
        if (value == null) {
    throw new NullPointerException();
  }
  
        stringValue_ = value;
        onChanged();
        return this;
      }
      /**
       * <pre>
       * char/varchar
       * </pre>
       *
       * <code>string string_value = 3;</code>
       * @return This builder for chaining.
       */
      public Builder clearStringValue() {
        
        stringValue_ = getDefaultInstance().getStringValue();
        onChanged();
        return this;
      }
      /**
       * <pre>
       * char/varchar
       * </pre>
       *
       * <code>string string_value = 3;</code>
       * @param value The bytes for stringValue to set.
       * @return This builder for chaining.
       */
      public Builder setStringValueBytes(
          com.google.protobuf.ByteString value) {
        if (value == null) {
    throw new NullPointerException();
  }
  checkByteStringIsUtf8(value);
        
        stringValue_ = value;
        onChanged();
        return this;
      }

      private long numberValue_ ;
      /**
       * <pre>
       * var-len encoding lets us shove anything from byte to long
       * </pre>
       *
       * <code>sint64 number_value = 4;</code>
       * @return The numberValue.
       */
      @java.lang.Override
      public long getNumberValue() {
        return numberValue_;
      }
      /**
       * <pre>
       * var-len encoding lets us shove anything from byte to long
       * </pre>
       *
       * <code>sint64 number_value = 4;</code>
       * @param value The numberValue to set.
       * @return This builder for chaining.
       */
      public Builder setNumberValue(long value) {
        
        numberValue_ = value;
        onChanged();
        return this;
      }
      /**
       * <pre>
       * var-len encoding lets us shove anything from byte to long
       * </pre>
       *
       * <code>sint64 number_value = 4;</code>
       * @return This builder for chaining.
       */
      public Builder clearNumberValue() {
        
        numberValue_ = 0L;
        onChanged();
        return this;
      }

      private com.google.protobuf.ByteString bytesValue_ = com.google.protobuf.ByteString.EMPTY;
      /**
       * <pre>
       * includes numeric types and date/time types.
       * </pre>
       *
       * <code>bytes bytes_value = 5;</code>
       * @return The bytesValue.
       */
      @java.lang.Override
      public com.google.protobuf.ByteString getBytesValue() {
        return bytesValue_;
      }
      /**
       * <pre>
       * includes numeric types and date/time types.
       * </pre>
       *
       * <code>bytes bytes_value = 5;</code>
       * @param value The bytesValue to set.
       * @return This builder for chaining.
       */
      public Builder setBytesValue(com.google.protobuf.ByteString value) {
        if (value == null) {
    throw new NullPointerException();
  }
  
        bytesValue_ = value;
        onChanged();
        return this;
      }
      /**
       * <pre>
       * includes numeric types and date/time types.
       * </pre>
       *
       * <code>bytes bytes_value = 5;</code>
       * @return This builder for chaining.
       */
      public Builder clearBytesValue() {
        
        bytesValue_ = getDefaultInstance().getBytesValue();
        onChanged();
        return this;
      }

      private double doubleValue_ ;
      /**
       * <pre>
       * big numbers
       * </pre>
       *
       * <code>double double_value = 6;</code>
       * @return The doubleValue.
       */
      @java.lang.Override
      public double getDoubleValue() {
        return doubleValue_;
      }
      /**
       * <pre>
       * big numbers
       * </pre>
       *
       * <code>double double_value = 6;</code>
       * @param value The doubleValue to set.
       * @return This builder for chaining.
       */
      public Builder setDoubleValue(double value) {
        
        doubleValue_ = value;
        onChanged();
        return this;
      }
      /**
       * <pre>
       * big numbers
       * </pre>
       *
       * <code>double double_value = 6;</code>
       * @return This builder for chaining.
       */
      public Builder clearDoubleValue() {
        
        doubleValue_ = 0D;
        onChanged();
        return this;
      }

      private boolean null_ ;
      /**
       * <pre>
       * a null object
       * </pre>
       *
       * <code>bool null = 7;</code>
       * @return The null.
       */
      @java.lang.Override
      public boolean getNull() {
        return null_;
      }
      /**
       * <pre>
       * a null object
       * </pre>
       *
       * <code>bool null = 7;</code>
       * @param value The null to set.
       * @return This builder for chaining.
       */
      public Builder setNull(boolean value) {
        
        null_ = value;
        onChanged();
        return this;
      }
      /**
       * <pre>
       * a null object
       * </pre>
       *
       * <code>bool null = 7;</code>
       * @return This builder for chaining.
       */
      public Builder clearNull() {
        
        null_ = false;
        onChanged();
        return this;
      }

      private java.util.List<org.apache.calcite.avatica.proto.Common.TypedValue> arrayValue_ =
        java.util.Collections.emptyList();
      private void ensureArrayValueIsMutable() {
        if (!((bitField0_ & 0x00000001) != 0)) {
          arrayValue_ = new java.util.ArrayList<org.apache.calcite.avatica.proto.Common.TypedValue>(arrayValue_);
          bitField0_ |= 0x00000001;
         }
      }

      private com.google.protobuf.RepeatedFieldBuilderV3<
          org.apache.calcite.avatica.proto.Common.TypedValue, org.apache.calcite.avatica.proto.Common.TypedValue.Builder, org.apache.calcite.avatica.proto.Common.TypedValueOrBuilder> arrayValueBuilder_;

      /**
       * <pre>
       * The Array
       * </pre>
       *
       * <code>repeated .TypedValue array_value = 8;</code>
       */
      public java.util.List<org.apache.calcite.avatica.proto.Common.TypedValue> getArrayValueList() {
        if (arrayValueBuilder_ == null) {
          return java.util.Collections.unmodifiableList(arrayValue_);
        } else {
          return arrayValueBuilder_.getMessageList();
        }
      }
      /**
       * <pre>
       * The Array
       * </pre>
       *
       * <code>repeated .TypedValue array_value = 8;</code>
       */
      public int getArrayValueCount() {
        if (arrayValueBuilder_ == null) {
          return arrayValue_.size();
        } else {
          return arrayValueBuilder_.getCount();
        }
      }
      /**
       * <pre>
       * The Array
       * </pre>
       *
       * <code>repeated .TypedValue array_value = 8;</code>
       */
      public org.apache.calcite.avatica.proto.Common.TypedValue getArrayValue(int index) {
        if (arrayValueBuilder_ == null) {
          return arrayValue_.get(index);
        } else {
          return arrayValueBuilder_.getMessage(index);
        }
      }
      /**
       * <pre>
       * The Array
       * </pre>
       *
       * <code>repeated .TypedValue array_value = 8;</code>
       */
      public Builder setArrayValue(
          int index, org.apache.calcite.avatica.proto.Common.TypedValue value) {
        if (arrayValueBuilder_ == null) {
          if (value == null) {
            throw new NullPointerException();
          }
          ensureArrayValueIsMutable();
          arrayValue_.set(index, value);
          onChanged();
        } else {
          arrayValueBuilder_.setMessage(index, value);
        }
        return this;
      }
      /**
       * <pre>
       * The Array
       * </pre>
       *
       * <code>repeated .TypedValue array_value = 8;</code>
       */
      public Builder setArrayValue(
          int index, org.apache.calcite.avatica.proto.Common.TypedValue.Builder builderForValue) {
        if (arrayValueBuilder_ == null) {
          ensureArrayValueIsMutable();
          arrayValue_.set(index, builderForValue.build());
          onChanged();
        } else {
          arrayValueBuilder_.setMessage(index, builderForValue.build());
        }
        return this;
      }
      /**
       * <pre>
       * The Array
       * </pre>
       *
       * <code>repeated .TypedValue array_value = 8;</code>
       */
      public Builder addArrayValue(org.apache.calcite.avatica.proto.Common.TypedValue value) {
        if (arrayValueBuilder_ == null) {
          if (value == null) {
            throw new NullPointerException();
          }
          ensureArrayValueIsMutable();
          arrayValue_.add(value);
          onChanged();
        } else {
          arrayValueBuilder_.addMessage(value);
        }
        return this;
      }
      /**
       * <pre>
       * The Array
       * </pre>
       *
       * <code>repeated .TypedValue array_value = 8;</code>
       */
      public Builder addArrayValue(
          int index, org.apache.calcite.avatica.proto.Common.TypedValue value) {
        if (arrayValueBuilder_ == null) {
          if (value == null) {
            throw new NullPointerException();
          }
          ensureArrayValueIsMutable();
          arrayValue_.add(index, value);
          onChanged();
        } else {
          arrayValueBuilder_.addMessage(index, value);
        }
        return this;
      }
      /**
       * <pre>
       * The Array
       * </pre>
       *
       * <code>repeated .TypedValue array_value = 8;</code>
       */
      public Builder addArrayValue(
          org.apache.calcite.avatica.proto.Common.TypedValue.Builder builderForValue) {
        if (arrayValueBuilder_ == null) {
          ensureArrayValueIsMutable();
          arrayValue_.add(builderForValue.build());
          onChanged();
        } else {
          arrayValueBuilder_.addMessage(builderForValue.build());
        }
        return this;
      }
      /**
       * <pre>
       * The Array
       * </pre>
       *
       * <code>repeated .TypedValue array_value = 8;</code>
       */
      public Builder addArrayValue(
          int index, org.apache.calcite.avatica.proto.Common.TypedValue.Builder builderForValue) {
        if (arrayValueBuilder_ == null) {
          ensureArrayValueIsMutable();
          arrayValue_.add(index, builderForValue.build());
          onChanged();
        } else {
          arrayValueBuilder_.addMessage(index, builderForValue.build());
        }
        return this;
      }
      /**
       * <pre>
       * The Array
       * </pre>
       *
       * <code>repeated .TypedValue array_value = 8;</code>
       */
      public Builder addAllArrayValue(
          java.lang.Iterable<? extends org.apache.calcite.avatica.proto.Common.TypedValue> values) {
        if (arrayValueBuilder_ == null) {
          ensureArrayValueIsMutable();
          com.google.protobuf.AbstractMessageLite.Builder.addAll(
              values, arrayValue_);
          onChanged();
        } else {
          arrayValueBuilder_.addAllMessages(values);
        }
        return this;
      }
      /**
       * <pre>
       * The Array
       * </pre>
       *
       * <code>repeated .TypedValue array_value = 8;</code>
       */
      public Builder clearArrayValue() {
        if (arrayValueBuilder_ == null) {
          arrayValue_ = java.util.Collections.emptyList();
          bitField0_ = (bitField0_ & ~0x00000001);
          onChanged();
        } else {
          arrayValueBuilder_.clear();
        }
        return this;
      }
      /**
       * <pre>
       * The Array
       * </pre>
       *
       * <code>repeated .TypedValue array_value = 8;</code>
       */
      public Builder removeArrayValue(int index) {
        if (arrayValueBuilder_ == null) {
          ensureArrayValueIsMutable();
          arrayValue_.remove(index);
          onChanged();
        } else {
          arrayValueBuilder_.remove(index);
        }
        return this;
      }
      /**
       * <pre>
       * The Array
       * </pre>
       *
       * <code>repeated .TypedValue array_value = 8;</code>
       */
      public org.apache.calcite.avatica.proto.Common.TypedValue.Builder getArrayValueBuilder(
          int index) {
        return getArrayValueFieldBuilder().getBuilder(index);
      }
      /**
       * <pre>
       * The Array
       * </pre>
       *
       * <code>repeated .TypedValue array_value = 8;</code>
       */
      public org.apache.calcite.avatica.proto.Common.TypedValueOrBuilder getArrayValueOrBuilder(
          int index) {
        if (arrayValueBuilder_ == null) {
          return arrayValue_.get(index);  } else {
          return arrayValueBuilder_.getMessageOrBuilder(index);
        }
      }
      /**
       * <pre>
       * The Array
       * </pre>
       *
       * <code>repeated .TypedValue array_value = 8;</code>
       */
      public java.util.List<? extends org.apache.calcite.avatica.proto.Common.TypedValueOrBuilder> 
           getArrayValueOrBuilderList() {
        if (arrayValueBuilder_ != null) {
          return arrayValueBuilder_.getMessageOrBuilderList();
        } else {
          return java.util.Collections.unmodifiableList(arrayValue_);
        }
      }
      /**
       * <pre>
       * The Array
       * </pre>
       *
       * <code>repeated .TypedValue array_value = 8;</code>
       */
      public org.apache.calcite.avatica.proto.Common.TypedValue.Builder addArrayValueBuilder() {
        return getArrayValueFieldBuilder().addBuilder(
            org.apache.calcite.avatica.proto.Common.TypedValue.getDefaultInstance());
      }
      /**
       * <pre>
       * The Array
       * </pre>
       *
       * <code>repeated .TypedValue array_value = 8;</code>
       */
      public org.apache.calcite.avatica.proto.Common.TypedValue.Builder addArrayValueBuilder(
          int index) {
        return getArrayValueFieldBuilder().addBuilder(
            index, org.apache.calcite.avatica.proto.Common.TypedValue.getDefaultInstance());
      }
      /**
       * <pre>
       * The Array
       * </pre>
       *
       * <code>repeated .TypedValue array_value = 8;</code>
       */
      public java.util.List<org.apache.calcite.avatica.proto.Common.TypedValue.Builder> 
           getArrayValueBuilderList() {
        return getArrayValueFieldBuilder().getBuilderList();
      }
      private com.google.protobuf.RepeatedFieldBuilderV3<
          org.apache.calcite.avatica.proto.Common.TypedValue, org.apache.calcite.avatica.proto.Common.TypedValue.Builder, org.apache.calcite.avatica.proto.Common.TypedValueOrBuilder> 
          getArrayValueFieldBuilder() {
        if (arrayValueBuilder_ == null) {
          arrayValueBuilder_ = new com.google.protobuf.RepeatedFieldBuilderV3<
              org.apache.calcite.avatica.proto.Common.TypedValue, org.apache.calcite.avatica.proto.Common.TypedValue.Builder, org.apache.calcite.avatica.proto.Common.TypedValueOrBuilder>(
                  arrayValue_,
                  ((bitField0_ & 0x00000001) != 0),
                  getParentForChildren(),
                  isClean());
          arrayValue_ = null;
        }
        return arrayValueBuilder_;
      }

      private int componentType_ = 0;
      /**
       * <pre>
       * If an Array, the representation for the array values
       * </pre>
       *
       * <code>.Rep component_type = 9;</code>
       * @return The enum numeric value on the wire for componentType.
       */
      @java.lang.Override public int getComponentTypeValue() {
        return componentType_;
      }
      /**
       * <pre>
       * If an Array, the representation for the array values
       * </pre>
       *
       * <code>.Rep component_type = 9;</code>
       * @param value The enum numeric value on the wire for componentType to set.
       * @return This builder for chaining.
       */
      public Builder setComponentTypeValue(int value) {
        
        componentType_ = value;
        onChanged();
        return this;
      }
      /**
       * <pre>
       * If an Array, the representation for the array values
       * </pre>
       *
       * <code>.Rep component_type = 9;</code>
       * @return The componentType.
       */
      @java.lang.Override
      public org.apache.calcite.avatica.proto.Common.Rep getComponentType() {
        @SuppressWarnings("deprecation")
        org.apache.calcite.avatica.proto.Common.Rep result = org.apache.calcite.avatica.proto.Common.Rep.valueOf(componentType_);
        return result == null ? org.apache.calcite.avatica.proto.Common.Rep.UNRECOGNIZED : result;
      }
      /**
       * <pre>
       * If an Array, the representation for the array values
       * </pre>
       *
       * <code>.Rep component_type = 9;</code>
       * @param value The componentType to set.
       * @return This builder for chaining.
       */
      public Builder setComponentType(org.apache.calcite.avatica.proto.Common.Rep value) {
        if (value == null) {
          throw new NullPointerException();
        }
        
        componentType_ = value.getNumber();
        onChanged();
        return this;
      }
      /**
       * <pre>
       * If an Array, the representation for the array values
       * </pre>
       *
       * <code>.Rep component_type = 9;</code>
       * @return This builder for chaining.
       */
      public Builder clearComponentType() {
        
        componentType_ = 0;
        onChanged();
        return this;
      }

      private boolean implicitlyNull_ ;
      /**
       * <pre>
       * Differentiate between explicitly null (user-set) and implicitly null
       * </pre>
       *
       * <code>bool implicitly_null = 10;</code>
       * @return The implicitlyNull.
       */
      @java.lang.Override
      public boolean getImplicitlyNull() {
        return implicitlyNull_;
      }
      /**
       * <pre>
       * Differentiate between explicitly null (user-set) and implicitly null
       * </pre>
       *
       * <code>bool implicitly_null = 10;</code>
       * @param value The implicitlyNull to set.
       * @return This builder for chaining.
       */
      public Builder setImplicitlyNull(boolean value) {
        
        implicitlyNull_ = value;
        onChanged();
        return this;
      }
      /**
       * <pre>
       * Differentiate between explicitly null (user-set) and implicitly null
       * </pre>
       *
       * <code>bool implicitly_null = 10;</code>
       * @return This builder for chaining.
       */
      public Builder clearImplicitlyNull() {
        
        implicitlyNull_ = false;
        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:TypedValue)
    }

    // @@protoc_insertion_point(class_scope:TypedValue)
    private static final org.apache.calcite.avatica.proto.Common.TypedValue DEFAULT_INSTANCE;
    static {
      DEFAULT_INSTANCE = new org.apache.calcite.avatica.proto.Common.TypedValue();
    }

    public static org.apache.calcite.avatica.proto.Common.TypedValue getDefaultInstance() {
      return DEFAULT_INSTANCE;
    }

    private static final com.google.protobuf.Parser<TypedValue>
        PARSER = new com.google.protobuf.AbstractParser<TypedValue>() {
      @java.lang.Override
      public TypedValue 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<TypedValue> parser() {
      return PARSER;
    }

    @java.lang.Override
    public com.google.protobuf.Parser<TypedValue> getParserForType() {
      return PARSER;
    }

    @java.lang.Override
    public org.apache.calcite.avatica.proto.Common.TypedValue getDefaultInstanceForType() {
      return DEFAULT_INSTANCE;
    }

  }

  public interface MetaDataOperationArgumentOrBuilder extends
      // @@protoc_insertion_point(interface_extends:MetaDataOperationArgument)
      com.google.protobuf.MessageOrBuilder {

    /**
     * <code>string string_value = 1;</code>
     * @return The stringValue.
     */
    java.lang.String getStringValue();
    /**
     * <code>string string_value = 1;</code>
     * @return The bytes for stringValue.
     */
    com.google.protobuf.ByteString
        getStringValueBytes();

    /**
     * <code>bool bool_value = 2;</code>
     * @return The boolValue.
     */
    boolean getBoolValue();

    /**
     * <code>sint32 int_value = 3;</code>
     * @return The intValue.
     */
    int getIntValue();

    /**
     * <code>repeated string string_array_values = 4;</code>
     * @return A list containing the stringArrayValues.
     */
    java.util.List<java.lang.String>
        getStringArrayValuesList();
    /**
     * <code>repeated string string_array_values = 4;</code>
     * @return The count of stringArrayValues.
     */
    int getStringArrayValuesCount();
    /**
     * <code>repeated string string_array_values = 4;</code>
     * @param index The index of the element to return.
     * @return The stringArrayValues at the given index.
     */
    java.lang.String getStringArrayValues(int index);
    /**
     * <code>repeated string string_array_values = 4;</code>
     * @param index The index of the value to return.
     * @return The bytes of the stringArrayValues at the given index.
     */
    com.google.protobuf.ByteString
        getStringArrayValuesBytes(int index);

    /**
     * <code>repeated sint32 int_array_values = 5;</code>
     * @return A list containing the intArrayValues.
     */
    java.util.List<java.lang.Integer> getIntArrayValuesList();
    /**
     * <code>repeated sint32 int_array_values = 5;</code>
     * @return The count of intArrayValues.
     */
    int getIntArrayValuesCount();
    /**
     * <code>repeated sint32 int_array_values = 5;</code>
     * @param index The index of the element to return.
     * @return The intArrayValues at the given index.
     */
    int getIntArrayValues(int index);

    /**
     * <code>.MetaDataOperationArgument.ArgumentType type = 6;</code>
     * @return The enum numeric value on the wire for type.
     */
    int getTypeValue();
    /**
     * <code>.MetaDataOperationArgument.ArgumentType type = 6;</code>
     * @return The type.
     */
    org.apache.calcite.avatica.proto.Common.MetaDataOperationArgument.ArgumentType getType();
  }
  /**
   * <pre>
   * Represents the breadth of arguments to DatabaseMetaData functions
   * </pre>
   *
   * Protobuf type {@code MetaDataOperationArgument}
   */
  public static final class MetaDataOperationArgument extends
      com.google.protobuf.GeneratedMessageV3 implements
      // @@protoc_insertion_point(message_implements:MetaDataOperationArgument)
      MetaDataOperationArgumentOrBuilder {
  private static final long serialVersionUID = 0L;
    // Use MetaDataOperationArgument.newBuilder() to construct.
    private MetaDataOperationArgument(com.google.protobuf.GeneratedMessageV3.Builder<?> builder) {
      super(builder);
    }
    private MetaDataOperationArgument() {
      stringValue_ = "";
      stringArrayValues_ = com.google.protobuf.LazyStringArrayList.EMPTY;
      intArrayValues_ = emptyIntList();
      type_ = 0;
    }

    @java.lang.Override
    @SuppressWarnings({"unused"})
    protected java.lang.Object newInstance(
        UnusedPrivateParameter unused) {
      return new MetaDataOperationArgument();
    }

    @java.lang.Override
    public final com.google.protobuf.UnknownFieldSet
    getUnknownFields() {
      return this.unknownFields;
    }
    public static final com.google.protobuf.Descriptors.Descriptor
        getDescriptor() {
      return org.apache.calcite.avatica.proto.Common.internal_static_MetaDataOperationArgument_descriptor;
    }

    @java.lang.Override
    protected com.google.protobuf.GeneratedMessageV3.FieldAccessorTable
        internalGetFieldAccessorTable() {
      return org.apache.calcite.avatica.proto.Common.internal_static_MetaDataOperationArgument_fieldAccessorTable
          .ensureFieldAccessorsInitialized(
              org.apache.calcite.avatica.proto.Common.MetaDataOperationArgument.class, org.apache.calcite.avatica.proto.Common.MetaDataOperationArgument.Builder.class);
    }

    /**
     * Protobuf enum {@code MetaDataOperationArgument.ArgumentType}
     */
    public enum ArgumentType
        implements com.google.protobuf.ProtocolMessageEnum {
      /**
       * <code>STRING = 0;</code>
       */
      STRING(0),
      /**
       * <code>BOOL = 1;</code>
       */
      BOOL(1),
      /**
       * <code>INT = 2;</code>
       */
      INT(2),
      /**
       * <code>REPEATED_STRING = 3;</code>
       */
      REPEATED_STRING(3),
      /**
       * <code>REPEATED_INT = 4;</code>
       */
      REPEATED_INT(4),
      /**
       * <code>NULL = 5;</code>
       */
      NULL(5),
      UNRECOGNIZED(-1),
      ;

      /**
       * <code>STRING = 0;</code>
       */
      public static final int STRING_VALUE = 0;
      /**
       * <code>BOOL = 1;</code>
       */
      public static final int BOOL_VALUE = 1;
      /**
       * <code>INT = 2;</code>
       */
      public static final int INT_VALUE = 2;
      /**
       * <code>REPEATED_STRING = 3;</code>
       */
      public static final int REPEATED_STRING_VALUE = 3;
      /**
       * <code>REPEATED_INT = 4;</code>
       */
      public static final int REPEATED_INT_VALUE = 4;
      /**
       * <code>NULL = 5;</code>
       */
      public static final int NULL_VALUE = 5;


      public final int getNumber() {
        if (this == UNRECOGNIZED) {
          throw new java.lang.IllegalArgumentException(
              "Can't get the number of an unknown enum value.");
        }
        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 ArgumentType 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 ArgumentType forNumber(int value) {
        switch (value) {
          case 0: return STRING;
          case 1: return BOOL;
          case 2: return INT;
          case 3: return REPEATED_STRING;
          case 4: return REPEATED_INT;
          case 5: return NULL;
          default: return null;
        }
      }

      public static com.google.protobuf.Internal.EnumLiteMap<ArgumentType>
          internalGetValueMap() {
        return internalValueMap;
      }
      private static final com.google.protobuf.Internal.EnumLiteMap<
          ArgumentType> internalValueMap =
            new com.google.protobuf.Internal.EnumLiteMap<ArgumentType>() {
              public ArgumentType findValueByNumber(int number) {
                return ArgumentType.forNumber(number);
              }
            };

      public final com.google.protobuf.Descriptors.EnumValueDescriptor
          getValueDescriptor() {
        if (this == UNRECOGNIZED) {
          throw new java.lang.IllegalStateException(
              "Can't get the descriptor of an unrecognized enum value.");
        }
        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 org.apache.calcite.avatica.proto.Common.MetaDataOperationArgument.getDescriptor().getEnumTypes().get(0);
      }

      private static final ArgumentType[] VALUES = values();

      public static ArgumentType valueOf(
          com.google.protobuf.Descriptors.EnumValueDescriptor desc) {
        if (desc.getType() != getDescriptor()) {
          throw new java.lang.IllegalArgumentException(
            "EnumValueDescriptor is not for this type.");
        }
        if (desc.getIndex() == -1) {
          return UNRECOGNIZED;
        }
        return VALUES[desc.getIndex()];
      }

      private final int value;

      private ArgumentType(int value) {
        this.value = value;
      }

      // @@protoc_insertion_point(enum_scope:MetaDataOperationArgument.ArgumentType)
    }

    public static final int STRING_VALUE_FIELD_NUMBER = 1;
    private volatile java.lang.Object stringValue_;
    /**
     * <code>string string_value = 1;</code>
     * @return The stringValue.
     */
    @java.lang.Override
    public java.lang.String getStringValue() {
      java.lang.Object ref = stringValue_;
      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();
        stringValue_ = s;
        return s;
      }
    }
    /**
     * <code>string string_value = 1;</code>
     * @return The bytes for stringValue.
     */
    @java.lang.Override
    public com.google.protobuf.ByteString
        getStringValueBytes() {
      java.lang.Object ref = stringValue_;
      if (ref instanceof java.lang.String) {
        com.google.protobuf.ByteString b = 
            com.google.protobuf.ByteString.copyFromUtf8(
                (java.lang.String) ref);
        stringValue_ = b;
        return b;
      } else {
        return (com.google.protobuf.ByteString) ref;
      }
    }

    public static final int BOOL_VALUE_FIELD_NUMBER = 2;
    private boolean boolValue_;
    /**
     * <code>bool bool_value = 2;</code>
     * @return The boolValue.
     */
    @java.lang.Override
    public boolean getBoolValue() {
      return boolValue_;
    }

    public static final int INT_VALUE_FIELD_NUMBER = 3;
    private int intValue_;
    /**
     * <code>sint32 int_value = 3;</code>
     * @return The intValue.
     */
    @java.lang.Override
    public int getIntValue() {
      return intValue_;
    }

    public static final int STRING_ARRAY_VALUES_FIELD_NUMBER = 4;
    private com.google.protobuf.LazyStringList stringArrayValues_;
    /**
     * <code>repeated string string_array_values = 4;</code>
     * @return A list containing the stringArrayValues.
     */
    public com.google.protobuf.ProtocolStringList
        getStringArrayValuesList() {
      return stringArrayValues_;
    }
    /**
     * <code>repeated string string_array_values = 4;</code>
     * @return The count of stringArrayValues.
     */
    public int getStringArrayValuesCount() {
      return stringArrayValues_.size();
    }
    /**
     * <code>repeated string string_array_values = 4;</code>
     * @param index The index of the element to return.
     * @return The stringArrayValues at the given index.
     */
    public java.lang.String getStringArrayValues(int index) {
      return stringArrayValues_.get(index);
    }
    /**
     * <code>repeated string string_array_values = 4;</code>
     * @param index The index of the value to return.
     * @return The bytes of the stringArrayValues at the given index.
     */
    public com.google.protobuf.ByteString
        getStringArrayValuesBytes(int index) {
      return stringArrayValues_.getByteString(index);
    }

    public static final int INT_ARRAY_VALUES_FIELD_NUMBER = 5;
    private com.google.protobuf.Internal.IntList intArrayValues_;
    /**
     * <code>repeated sint32 int_array_values = 5;</code>
     * @return A list containing the intArrayValues.
     */
    @java.lang.Override
    public java.util.List<java.lang.Integer>
        getIntArrayValuesList() {
      return intArrayValues_;
    }
    /**
     * <code>repeated sint32 int_array_values = 5;</code>
     * @return The count of intArrayValues.
     */
    public int getIntArrayValuesCount() {
      return intArrayValues_.size();
    }
    /**
     * <code>repeated sint32 int_array_values = 5;</code>
     * @param index The index of the element to return.
     * @return The intArrayValues at the given index.
     */
    public int getIntArrayValues(int index) {
      return intArrayValues_.getInt(index);
    }
    private int intArrayValuesMemoizedSerializedSize = -1;

    public static final int TYPE_FIELD_NUMBER = 6;
    private int type_;
    /**
     * <code>.MetaDataOperationArgument.ArgumentType type = 6;</code>
     * @return The enum numeric value on the wire for type.
     */
    @java.lang.Override public int getTypeValue() {
      return type_;
    }
    /**
     * <code>.MetaDataOperationArgument.ArgumentType type = 6;</code>
     * @return The type.
     */
    @java.lang.Override public org.apache.calcite.avatica.proto.Common.MetaDataOperationArgument.ArgumentType getType() {
      @SuppressWarnings("deprecation")
      org.apache.calcite.avatica.proto.Common.MetaDataOperationArgument.ArgumentType result = org.apache.calcite.avatica.proto.Common.MetaDataOperationArgument.ArgumentType.valueOf(type_);
      return result == null ? org.apache.calcite.avatica.proto.Common.MetaDataOperationArgument.ArgumentType.UNRECOGNIZED : result;
    }

    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 {
      getSerializedSize();
      if (!com.google.protobuf.GeneratedMessageV3.isStringEmpty(stringValue_)) {
        com.google.protobuf.GeneratedMessageV3.writeString(output, 1, stringValue_);
      }
      if (boolValue_ != false) {
        output.writeBool(2, boolValue_);
      }
      if (intValue_ != 0) {
        output.writeSInt32(3, intValue_);
      }
      for (int i = 0; i < stringArrayValues_.size(); i++) {
        com.google.protobuf.GeneratedMessageV3.writeString(output, 4, stringArrayValues_.getRaw(i));
      }
      if (getIntArrayValuesList().size() > 0) {
        output.writeUInt32NoTag(42);
        output.writeUInt32NoTag(intArrayValuesMemoizedSerializedSize);
      }
      for (int i = 0; i < intArrayValues_.size(); i++) {
        output.writeSInt32NoTag(intArrayValues_.getInt(i));
      }
      if (type_ != org.apache.calcite.avatica.proto.Common.MetaDataOperationArgument.ArgumentType.STRING.getNumber()) {
        output.writeEnum(6, type_);
      }
      getUnknownFields().writeTo(output);
    }

    @java.lang.Override
    public int getSerializedSize() {
      int size = memoizedSize;
      if (size != -1) return size;

      size = 0;
      if (!com.google.protobuf.GeneratedMessageV3.isStringEmpty(stringValue_)) {
        size += com.google.protobuf.GeneratedMessageV3.computeStringSize(1, stringValue_);
      }
      if (boolValue_ != false) {
        size += com.google.protobuf.CodedOutputStream
          .computeBoolSize(2, boolValue_);
      }
      if (intValue_ != 0) {
        size += com.google.protobuf.CodedOutputStream
          .computeSInt32Size(3, intValue_);
      }
      {
        int dataSize = 0;
        for (int i = 0; i < stringArrayValues_.size(); i++) {
          dataSize += computeStringSizeNoTag(stringArrayValues_.getRaw(i));
        }
        size += dataSize;
        size += 1 * getStringArrayValuesList().size();
      }
      {
        int dataSize = 0;
        for (int i = 0; i < intArrayValues_.size(); i++) {
          dataSize += com.google.protobuf.CodedOutputStream
            .computeSInt32SizeNoTag(intArrayValues_.getInt(i));
        }
        size += dataSize;
        if (!getIntArrayValuesList().isEmpty()) {
          size += 1;
          size += com.google.protobuf.CodedOutputStream
              .computeInt32SizeNoTag(dataSize);
        }
        intArrayValuesMemoizedSerializedSize = dataSize;
      }
      if (type_ != org.apache.calcite.avatica.proto.Common.MetaDataOperationArgument.ArgumentType.STRING.getNumber()) {
        size += com.google.protobuf.CodedOutputStream
          .computeEnumSize(6, type_);
      }
      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 org.apache.calcite.avatica.proto.Common.MetaDataOperationArgument)) {
        return super.equals(obj);
      }
      org.apache.calcite.avatica.proto.Common.MetaDataOperationArgument other = (org.apache.calcite.avatica.proto.Common.MetaDataOperationArgument) obj;

      if (!getStringValue()
          .equals(other.getStringValue())) return false;
      if (getBoolValue()
          != other.getBoolValue()) return false;
      if (getIntValue()
          != other.getIntValue()) return false;
      if (!getStringArrayValuesList()
          .equals(other.getStringArrayValuesList())) return false;
      if (!getIntArrayValuesList()
          .equals(other.getIntArrayValuesList())) return false;
      if (type_ != other.type_) 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();
      hash = (37 * hash) + STRING_VALUE_FIELD_NUMBER;
      hash = (53 * hash) + getStringValue().hashCode();
      hash = (37 * hash) + BOOL_VALUE_FIELD_NUMBER;
      hash = (53 * hash) + com.google.protobuf.Internal.hashBoolean(
          getBoolValue());
      hash = (37 * hash) + INT_VALUE_FIELD_NUMBER;
      hash = (53 * hash) + getIntValue();
      if (getStringArrayValuesCount() > 0) {
        hash = (37 * hash) + STRING_ARRAY_VALUES_FIELD_NUMBER;
        hash = (53 * hash) + getStringArrayValuesList().hashCode();
      }
      if (getIntArrayValuesCount() > 0) {
        hash = (37 * hash) + INT_ARRAY_VALUES_FIELD_NUMBER;
        hash = (53 * hash) + getIntArrayValuesList().hashCode();
      }
      hash = (37 * hash) + TYPE_FIELD_NUMBER;
      hash = (53 * hash) + type_;
      hash = (29 * hash) + getUnknownFields().hashCode();
      memoizedHashCode = hash;
      return hash;
    }

    public static org.apache.calcite.avatica.proto.Common.MetaDataOperationArgument parseFrom(
        java.nio.ByteBuffer data)
        throws com.google.protobuf.InvalidProtocolBufferException {
      return PARSER.parseFrom(data);
    }
    public static org.apache.calcite.avatica.proto.Common.MetaDataOperationArgument parseFrom(
        java.nio.ByteBuffer data,
        com.google.protobuf.ExtensionRegistryLite extensionRegistry)
        throws com.google.protobuf.InvalidProtocolBufferException {
      return PARSER.parseFrom(data, extensionRegistry);
    }
    public static org.apache.calcite.avatica.proto.Common.MetaDataOperationArgument parseFrom(
        com.google.protobuf.ByteString data)
        throws com.google.protobuf.InvalidProtocolBufferException {
      return PARSER.parseFrom(data);
    }
    public static org.apache.calcite.avatica.proto.Common.MetaDataOperationArgument parseFrom(
        com.google.protobuf.ByteString data,
        com.google.protobuf.ExtensionRegistryLite extensionRegistry)
        throws com.google.protobuf.InvalidProtocolBufferException {
      return PARSER.parseFrom(data, extensionRegistry);
    }
    public static org.apache.calcite.avatica.proto.Common.MetaDataOperationArgument parseFrom(byte[] data)
        throws com.google.protobuf.InvalidProtocolBufferException {
      return PARSER.parseFrom(data);
    }
    public static org.apache.calcite.avatica.proto.Common.MetaDataOperationArgument parseFrom(
        byte[] data,
        com.google.protobuf.ExtensionRegistryLite extensionRegistry)
        throws com.google.protobuf.InvalidProtocolBufferException {
      return PARSER.parseFrom(data, extensionRegistry);
    }
    public static org.apache.calcite.avatica.proto.Common.MetaDataOperationArgument parseFrom(java.io.InputStream input)
        throws java.io.IOException {
      return com.google.protobuf.GeneratedMessageV3
          .parseWithIOException(PARSER, input);
    }
    public static org.apache.calcite.avatica.proto.Common.MetaDataOperationArgument 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 org.apache.calcite.avatica.proto.Common.MetaDataOperationArgument parseDelimitedFrom(java.io.InputStream input)
        throws java.io.IOException {
      return com.google.protobuf.GeneratedMessageV3
          .parseDelimitedWithIOException(PARSER, input);
    }
    public static org.apache.calcite.avatica.proto.Common.MetaDataOperationArgument 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 org.apache.calcite.avatica.proto.Common.MetaDataOperationArgument parseFrom(
        com.google.protobuf.CodedInputStream input)
        throws java.io.IOException {
      return com.google.protobuf.GeneratedMessageV3
          .parseWithIOException(PARSER, input);
    }
    public static org.apache.calcite.avatica.proto.Common.MetaDataOperationArgument 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(org.apache.calcite.avatica.proto.Common.MetaDataOperationArgument 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;
    }
    /**
     * <pre>
     * Represents the breadth of arguments to DatabaseMetaData functions
     * </pre>
     *
     * Protobuf type {@code MetaDataOperationArgument}
     */
    public static final class Builder extends
        com.google.protobuf.GeneratedMessageV3.Builder<Builder> implements
        // @@protoc_insertion_point(builder_implements:MetaDataOperationArgument)
        org.apache.calcite.avatica.proto.Common.MetaDataOperationArgumentOrBuilder {
      public static final com.google.protobuf.Descriptors.Descriptor
          getDescriptor() {
        return org.apache.calcite.avatica.proto.Common.internal_static_MetaDataOperationArgument_descriptor;
      }

      @java.lang.Override
      protected com.google.protobuf.GeneratedMessageV3.FieldAccessorTable
          internalGetFieldAccessorTable() {
        return org.apache.calcite.avatica.proto.Common.internal_static_MetaDataOperationArgument_fieldAccessorTable
            .ensureFieldAccessorsInitialized(
                org.apache.calcite.avatica.proto.Common.MetaDataOperationArgument.class, org.apache.calcite.avatica.proto.Common.MetaDataOperationArgument.Builder.class);
      }

      // Construct using org.apache.calcite.avatica.proto.Common.MetaDataOperationArgument.newBuilder()
      private Builder() {

      }

      private Builder(
          com.google.protobuf.GeneratedMessageV3.BuilderParent parent) {
        super(parent);

      }
      @java.lang.Override
      public Builder clear() {
        super.clear();
        stringValue_ = "";

        boolValue_ = false;

        intValue_ = 0;

        stringArrayValues_ = com.google.protobuf.LazyStringArrayList.EMPTY;
        bitField0_ = (bitField0_ & ~0x00000001);
        intArrayValues_ = emptyIntList();
        bitField0_ = (bitField0_ & ~0x00000002);
        type_ = 0;

        return this;
      }

      @java.lang.Override
      public com.google.protobuf.Descriptors.Descriptor
          getDescriptorForType() {
        return org.apache.calcite.avatica.proto.Common.internal_static_MetaDataOperationArgument_descriptor;
      }

      @java.lang.Override
      public org.apache.calcite.avatica.proto.Common.MetaDataOperationArgument getDefaultInstanceForType() {
        return org.apache.calcite.avatica.proto.Common.MetaDataOperationArgument.getDefaultInstance();
      }

      @java.lang.Override
      public org.apache.calcite.avatica.proto.Common.MetaDataOperationArgument build() {
        org.apache.calcite.avatica.proto.Common.MetaDataOperationArgument result = buildPartial();
        if (!result.isInitialized()) {
          throw newUninitializedMessageException(result);
        }
        return result;
      }

      @java.lang.Override
      public org.apache.calcite.avatica.proto.Common.MetaDataOperationArgument buildPartial() {
        org.apache.calcite.avatica.proto.Common.MetaDataOperationArgument result = new org.apache.calcite.avatica.proto.Common.MetaDataOperationArgument(this);
        int from_bitField0_ = bitField0_;
        result.stringValue_ = stringValue_;
        result.boolValue_ = boolValue_;
        result.intValue_ = intValue_;
        if (((bitField0_ & 0x00000001) != 0)) {
          stringArrayValues_ = stringArrayValues_.getUnmodifiableView();
          bitField0_ = (bitField0_ & ~0x00000001);
        }
        result.stringArrayValues_ = stringArrayValues_;
        if (((bitField0_ & 0x00000002) != 0)) {
          intArrayValues_.makeImmutable();
          bitField0_ = (bitField0_ & ~0x00000002);
        }
        result.intArrayValues_ = intArrayValues_;
        result.type_ = type_;
        onBuilt();
        return result;
      }

      @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 org.apache.calcite.avatica.proto.Common.MetaDataOperationArgument) {
          return mergeFrom((org.apache.calcite.avatica.proto.Common.MetaDataOperationArgument)other);
        } else {
          super.mergeFrom(other);
          return this;
        }
      }

      public Builder mergeFrom(org.apache.calcite.avatica.proto.Common.MetaDataOperationArgument other) {
        if (other == org.apache.calcite.avatica.proto.Common.MetaDataOperationArgument.getDefaultInstance()) return this;
        if (!other.getStringValue().isEmpty()) {
          stringValue_ = other.stringValue_;
          onChanged();
        }
        if (other.getBoolValue() != false) {
          setBoolValue(other.getBoolValue());
        }
        if (other.getIntValue() != 0) {
          setIntValue(other.getIntValue());
        }
        if (!other.stringArrayValues_.isEmpty()) {
          if (stringArrayValues_.isEmpty()) {
            stringArrayValues_ = other.stringArrayValues_;
            bitField0_ = (bitField0_ & ~0x00000001);
          } else {
            ensureStringArrayValuesIsMutable();
            stringArrayValues_.addAll(other.stringArrayValues_);
          }
          onChanged();
        }
        if (!other.intArrayValues_.isEmpty()) {
          if (intArrayValues_.isEmpty()) {
            intArrayValues_ = other.intArrayValues_;
            bitField0_ = (bitField0_ & ~0x00000002);
          } else {
            ensureIntArrayValuesIsMutable();
            intArrayValues_.addAll(other.intArrayValues_);
          }
          onChanged();
        }
        if (other.type_ != 0) {
          setTypeValue(other.getTypeValue());
        }
        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: {
                stringValue_ = input.readStringRequireUtf8();

                break;
              } // case 10
              case 16: {
                boolValue_ = input.readBool();

                break;
              } // case 16
              case 24: {
                intValue_ = input.readSInt32();

                break;
              } // case 24
              case 34: {
                java.lang.String s = input.readStringRequireUtf8();
                ensureStringArrayValuesIsMutable();
                stringArrayValues_.add(s);
                break;
              } // case 34
              case 40: {
                int v = input.readSInt32();
                ensureIntArrayValuesIsMutable();
                intArrayValues_.addInt(v);
                break;
              } // case 40
              case 42: {
                int length = input.readRawVarint32();
                int limit = input.pushLimit(length);
                ensureIntArrayValuesIsMutable();
                while (input.getBytesUntilLimit() > 0) {
                  intArrayValues_.addInt(input.readSInt32());
                }
                input.popLimit(limit);
                break;
              } // case 42
              case 48: {
                type_ = input.readEnum();

                break;
              } // case 48
              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 stringValue_ = "";
      /**
       * <code>string string_value = 1;</code>
       * @return The stringValue.
       */
      public java.lang.String getStringValue() {
        java.lang.Object ref = stringValue_;
        if (!(ref instanceof java.lang.String)) {
          com.google.protobuf.ByteString bs =
              (com.google.protobuf.ByteString) ref;
          java.lang.String s = bs.toStringUtf8();
          stringValue_ = s;
          return s;
        } else {
          return (java.lang.String) ref;
        }
      }
      /**
       * <code>string string_value = 1;</code>
       * @return The bytes for stringValue.
       */
      public com.google.protobuf.ByteString
          getStringValueBytes() {
        java.lang.Object ref = stringValue_;
        if (ref instanceof String) {
          com.google.protobuf.ByteString b = 
              com.google.protobuf.ByteString.copyFromUtf8(
                  (java.lang.String) ref);
          stringValue_ = b;
          return b;
        } else {
          return (com.google.protobuf.ByteString) ref;
        }
      }
      /**
       * <code>string string_value = 1;</code>
       * @param value The stringValue to set.
       * @return This builder for chaining.
       */
      public Builder setStringValue(
          java.lang.String value) {
        if (value == null) {
    throw new NullPointerException();
  }
  
        stringValue_ = value;
        onChanged();
        return this;
      }
      /**
       * <code>string string_value = 1;</code>
       * @return This builder for chaining.
       */
      public Builder clearStringValue() {
        
        stringValue_ = getDefaultInstance().getStringValue();
        onChanged();
        return this;
      }
      /**
       * <code>string string_value = 1;</code>
       * @param value The bytes for stringValue to set.
       * @return This builder for chaining.
       */
      public Builder setStringValueBytes(
          com.google.protobuf.ByteString value) {
        if (value == null) {
    throw new NullPointerException();
  }
  checkByteStringIsUtf8(value);
        
        stringValue_ = value;
        onChanged();
        return this;
      }

      private boolean boolValue_ ;
      /**
       * <code>bool bool_value = 2;</code>
       * @return The boolValue.
       */
      @java.lang.Override
      public boolean getBoolValue() {
        return boolValue_;
      }
      /**
       * <code>bool bool_value = 2;</code>
       * @param value The boolValue to set.
       * @return This builder for chaining.
       */
      public Builder setBoolValue(boolean value) {
        
        boolValue_ = value;
        onChanged();
        return this;
      }
      /**
       * <code>bool bool_value = 2;</code>
       * @return This builder for chaining.
       */
      public Builder clearBoolValue() {
        
        boolValue_ = false;
        onChanged();
        return this;
      }

      private int intValue_ ;
      /**
       * <code>sint32 int_value = 3;</code>
       * @return The intValue.
       */
      @java.lang.Override
      public int getIntValue() {
        return intValue_;
      }
      /**
       * <code>sint32 int_value = 3;</code>
       * @param value The intValue to set.
       * @return This builder for chaining.
       */
      public Builder setIntValue(int value) {
        
        intValue_ = value;
        onChanged();
        return this;
      }
      /**
       * <code>sint32 int_value = 3;</code>
       * @return This builder for chaining.
       */
      public Builder clearIntValue() {
        
        intValue_ = 0;
        onChanged();
        return this;
      }

      private com.google.protobuf.LazyStringList stringArrayValues_ = com.google.protobuf.LazyStringArrayList.EMPTY;
      private void ensureStringArrayValuesIsMutable() {
        if (!((bitField0_ & 0x00000001) != 0)) {
          stringArrayValues_ = new com.google.protobuf.LazyStringArrayList(stringArrayValues_);
          bitField0_ |= 0x00000001;
         }
      }
      /**
       * <code>repeated string string_array_values = 4;</code>
       * @return A list containing the stringArrayValues.
       */
      public com.google.protobuf.ProtocolStringList
          getStringArrayValuesList() {
        return stringArrayValues_.getUnmodifiableView();
      }
      /**
       * <code>repeated string string_array_values = 4;</code>
       * @return The count of stringArrayValues.
       */
      public int getStringArrayValuesCount() {
        return stringArrayValues_.size();
      }
      /**
       * <code>repeated string string_array_values = 4;</code>
       * @param index The index of the element to return.
       * @return The stringArrayValues at the given index.
       */
      public java.lang.String getStringArrayValues(int index) {
        return stringArrayValues_.get(index);
      }
      /**
       * <code>repeated string string_array_values = 4;</code>
       * @param index The index of the value to return.
       * @return The bytes of the stringArrayValues at the given index.
       */
      public com.google.protobuf.ByteString
          getStringArrayValuesBytes(int index) {
        return stringArrayValues_.getByteString(index);
      }
      /**
       * <code>repeated string string_array_values = 4;</code>
       * @param index The index to set the value at.
       * @param value The stringArrayValues to set.
       * @return This builder for chaining.
       */
      public Builder setStringArrayValues(
          int index, java.lang.String value) {
        if (value == null) {
    throw new NullPointerException();
  }
  ensureStringArrayValuesIsMutable();
        stringArrayValues_.set(index, value);
        onChanged();
        return this;
      }
      /**
       * <code>repeated string string_array_values = 4;</code>
       * @param value The stringArrayValues to add.
       * @return This builder for chaining.
       */
      public Builder addStringArrayValues(
          java.lang.String value) {
        if (value == null) {
    throw new NullPointerException();
  }
  ensureStringArrayValuesIsMutable();
        stringArrayValues_.add(value);
        onChanged();
        return this;
      }
      /**
       * <code>repeated string string_array_values = 4;</code>
       * @param values The stringArrayValues to add.
       * @return This builder for chaining.
       */
      public Builder addAllStringArrayValues(
          java.lang.Iterable<java.lang.String> values) {
        ensureStringArrayValuesIsMutable();
        com.google.protobuf.AbstractMessageLite.Builder.addAll(
            values, stringArrayValues_);
        onChanged();
        return this;
      }
      /**
       * <code>repeated string string_array_values = 4;</code>
       * @return This builder for chaining.
       */
      public Builder clearStringArrayValues() {
        stringArrayValues_ = com.google.protobuf.LazyStringArrayList.EMPTY;
        bitField0_ = (bitField0_ & ~0x00000001);
        onChanged();
        return this;
      }
      /**
       * <code>repeated string string_array_values = 4;</code>
       * @param value The bytes of the stringArrayValues to add.
       * @return This builder for chaining.
       */
      public Builder addStringArrayValuesBytes(
          com.google.protobuf.ByteString value) {
        if (value == null) {
    throw new NullPointerException();
  }
  checkByteStringIsUtf8(value);
        ensureStringArrayValuesIsMutable();
        stringArrayValues_.add(value);
        onChanged();
        return this;
      }

      private com.google.protobuf.Internal.IntList intArrayValues_ = emptyIntList();
      private void ensureIntArrayValuesIsMutable() {
        if (!((bitField0_ & 0x00000002) != 0)) {
          intArrayValues_ = mutableCopy(intArrayValues_);
          bitField0_ |= 0x00000002;
         }
      }
      /**
       * <code>repeated sint32 int_array_values = 5;</code>
       * @return A list containing the intArrayValues.
       */
      public java.util.List<java.lang.Integer>
          getIntArrayValuesList() {
        return ((bitField0_ & 0x00000002) != 0) ?
                 java.util.Collections.unmodifiableList(intArrayValues_) : intArrayValues_;
      }
      /**
       * <code>repeated sint32 int_array_values = 5;</code>
       * @return The count of intArrayValues.
       */
      public int getIntArrayValuesCount() {
        return intArrayValues_.size();
      }
      /**
       * <code>repeated sint32 int_array_values = 5;</code>
       * @param index The index of the element to return.
       * @return The intArrayValues at the given index.
       */
      public int getIntArrayValues(int index) {
        return intArrayValues_.getInt(index);
      }
      /**
       * <code>repeated sint32 int_array_values = 5;</code>
       * @param index The index to set the value at.
       * @param value The intArrayValues to set.
       * @return This builder for chaining.
       */
      public Builder setIntArrayValues(
          int index, int value) {
        ensureIntArrayValuesIsMutable();
        intArrayValues_.setInt(index, value);
        onChanged();
        return this;
      }
      /**
       * <code>repeated sint32 int_array_values = 5;</code>
       * @param value The intArrayValues to add.
       * @return This builder for chaining.
       */
      public Builder addIntArrayValues(int value) {
        ensureIntArrayValuesIsMutable();
        intArrayValues_.addInt(value);
        onChanged();
        return this;
      }
      /**
       * <code>repeated sint32 int_array_values = 5;</code>
       * @param values The intArrayValues to add.
       * @return This builder for chaining.
       */
      public Builder addAllIntArrayValues(
          java.lang.Iterable<? extends java.lang.Integer> values) {
        ensureIntArrayValuesIsMutable();
        com.google.protobuf.AbstractMessageLite.Builder.addAll(
            values, intArrayValues_);
        onChanged();
        return this;
      }
      /**
       * <code>repeated sint32 int_array_values = 5;</code>
       * @return This builder for chaining.
       */
      public Builder clearIntArrayValues() {
        intArrayValues_ = emptyIntList();
        bitField0_ = (bitField0_ & ~0x00000002);
        onChanged();
        return this;
      }

      private int type_ = 0;
      /**
       * <code>.MetaDataOperationArgument.ArgumentType type = 6;</code>
       * @return The enum numeric value on the wire for type.
       */
      @java.lang.Override public int getTypeValue() {
        return type_;
      }
      /**
       * <code>.MetaDataOperationArgument.ArgumentType type = 6;</code>
       * @param value The enum numeric value on the wire for type to set.
       * @return This builder for chaining.
       */
      public Builder setTypeValue(int value) {
        
        type_ = value;
        onChanged();
        return this;
      }
      /**
       * <code>.MetaDataOperationArgument.ArgumentType type = 6;</code>
       * @return The type.
       */
      @java.lang.Override
      public org.apache.calcite.avatica.proto.Common.MetaDataOperationArgument.ArgumentType getType() {
        @SuppressWarnings("deprecation")
        org.apache.calcite.avatica.proto.Common.MetaDataOperationArgument.ArgumentType result = org.apache.calcite.avatica.proto.Common.MetaDataOperationArgument.ArgumentType.valueOf(type_);
        return result == null ? org.apache.calcite.avatica.proto.Common.MetaDataOperationArgument.ArgumentType.UNRECOGNIZED : result;
      }
      /**
       * <code>.MetaDataOperationArgument.ArgumentType type = 6;</code>
       * @param value The type to set.
       * @return This builder for chaining.
       */
      public Builder setType(org.apache.calcite.avatica.proto.Common.MetaDataOperationArgument.ArgumentType value) {
        if (value == null) {
          throw new NullPointerException();
        }
        
        type_ = value.getNumber();
        onChanged();
        return this;
      }
      /**
       * <code>.MetaDataOperationArgument.ArgumentType type = 6;</code>
       * @return This builder for chaining.
       */
      public Builder clearType() {
        
        type_ = 0;
        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:MetaDataOperationArgument)
    }

    // @@protoc_insertion_point(class_scope:MetaDataOperationArgument)
    private static final org.apache.calcite.avatica.proto.Common.MetaDataOperationArgument DEFAULT_INSTANCE;
    static {
      DEFAULT_INSTANCE = new org.apache.calcite.avatica.proto.Common.MetaDataOperationArgument();
    }

    public static org.apache.calcite.avatica.proto.Common.MetaDataOperationArgument getDefaultInstance() {
      return DEFAULT_INSTANCE;
    }

    private static final com.google.protobuf.Parser<MetaDataOperationArgument>
        PARSER = new com.google.protobuf.AbstractParser<MetaDataOperationArgument>() {
      @java.lang.Override
      public MetaDataOperationArgument 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<MetaDataOperationArgument> parser() {
      return PARSER;
    }

    @java.lang.Override
    public com.google.protobuf.Parser<MetaDataOperationArgument> getParserForType() {
      return PARSER;
    }

    @java.lang.Override
    public org.apache.calcite.avatica.proto.Common.MetaDataOperationArgument getDefaultInstanceForType() {
      return DEFAULT_INSTANCE;
    }

  }

  public interface QueryStateOrBuilder extends
      // @@protoc_insertion_point(interface_extends:QueryState)
      com.google.protobuf.MessageOrBuilder {

    /**
     * <code>.StateType type = 1;</code>
     * @return The enum numeric value on the wire for type.
     */
    int getTypeValue();
    /**
     * <code>.StateType type = 1;</code>
     * @return The type.
     */
    org.apache.calcite.avatica.proto.Common.StateType getType();

    /**
     * <code>string sql = 2;</code>
     * @return The sql.
     */
    java.lang.String getSql();
    /**
     * <code>string sql = 2;</code>
     * @return The bytes for sql.
     */
    com.google.protobuf.ByteString
        getSqlBytes();

    /**
     * <code>.MetaDataOperation op = 3;</code>
     * @return The enum numeric value on the wire for op.
     */
    int getOpValue();
    /**
     * <code>.MetaDataOperation op = 3;</code>
     * @return The op.
     */
    org.apache.calcite.avatica.proto.Common.MetaDataOperation getOp();

    /**
     * <code>repeated .MetaDataOperationArgument args = 4;</code>
     */
    java.util.List<org.apache.calcite.avatica.proto.Common.MetaDataOperationArgument> 
        getArgsList();
    /**
     * <code>repeated .MetaDataOperationArgument args = 4;</code>
     */
    org.apache.calcite.avatica.proto.Common.MetaDataOperationArgument getArgs(int index);
    /**
     * <code>repeated .MetaDataOperationArgument args = 4;</code>
     */
    int getArgsCount();
    /**
     * <code>repeated .MetaDataOperationArgument args = 4;</code>
     */
    java.util.List<? extends org.apache.calcite.avatica.proto.Common.MetaDataOperationArgumentOrBuilder> 
        getArgsOrBuilderList();
    /**
     * <code>repeated .MetaDataOperationArgument args = 4;</code>
     */
    org.apache.calcite.avatica.proto.Common.MetaDataOperationArgumentOrBuilder getArgsOrBuilder(
        int index);

    /**
     * <code>bool has_args = 5;</code>
     * @return The hasArgs.
     */
    boolean getHasArgs();

    /**
     * <code>bool has_sql = 6;</code>
     * @return The hasSql.
     */
    boolean getHasSql();

    /**
     * <code>bool has_op = 7;</code>
     * @return The hasOp.
     */
    boolean getHasOp();
  }
  /**
   * Protobuf type {@code QueryState}
   */
  public static final class QueryState extends
      com.google.protobuf.GeneratedMessageV3 implements
      // @@protoc_insertion_point(message_implements:QueryState)
      QueryStateOrBuilder {
  private static final long serialVersionUID = 0L;
    // Use QueryState.newBuilder() to construct.
    private QueryState(com.google.protobuf.GeneratedMessageV3.Builder<?> builder) {
      super(builder);
    }
    private QueryState() {
      type_ = 0;
      sql_ = "";
      op_ = 0;
      args_ = java.util.Collections.emptyList();
    }

    @java.lang.Override
    @SuppressWarnings({"unused"})
    protected java.lang.Object newInstance(
        UnusedPrivateParameter unused) {
      return new QueryState();
    }

    @java.lang.Override
    public final com.google.protobuf.UnknownFieldSet
    getUnknownFields() {
      return this.unknownFields;
    }
    public static final com.google.protobuf.Descriptors.Descriptor
        getDescriptor() {
      return org.apache.calcite.avatica.proto.Common.internal_static_QueryState_descriptor;
    }

    @java.lang.Override
    protected com.google.protobuf.GeneratedMessageV3.FieldAccessorTable
        internalGetFieldAccessorTable() {
      return org.apache.calcite.avatica.proto.Common.internal_static_QueryState_fieldAccessorTable
          .ensureFieldAccessorsInitialized(
              org.apache.calcite.avatica.proto.Common.QueryState.class, org.apache.calcite.avatica.proto.Common.QueryState.Builder.class);
    }

    public static final int TYPE_FIELD_NUMBER = 1;
    private int type_;
    /**
     * <code>.StateType type = 1;</code>
     * @return The enum numeric value on the wire for type.
     */
    @java.lang.Override public int getTypeValue() {
      return type_;
    }
    /**
     * <code>.StateType type = 1;</code>
     * @return The type.
     */
    @java.lang.Override public org.apache.calcite.avatica.proto.Common.StateType getType() {
      @SuppressWarnings("deprecation")
      org.apache.calcite.avatica.proto.Common.StateType result = org.apache.calcite.avatica.proto.Common.StateType.valueOf(type_);
      return result == null ? org.apache.calcite.avatica.proto.Common.StateType.UNRECOGNIZED : result;
    }

    public static final int SQL_FIELD_NUMBER = 2;
    private volatile java.lang.Object sql_;
    /**
     * <code>string sql = 2;</code>
     * @return The sql.
     */
    @java.lang.Override
    public java.lang.String getSql() {
      java.lang.Object ref = sql_;
      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();
        sql_ = s;
        return s;
      }
    }
    /**
     * <code>string sql = 2;</code>
     * @return The bytes for sql.
     */
    @java.lang.Override
    public com.google.protobuf.ByteString
        getSqlBytes() {
      java.lang.Object ref = sql_;
      if (ref instanceof java.lang.String) {
        com.google.protobuf.ByteString b = 
            com.google.protobuf.ByteString.copyFromUtf8(
                (java.lang.String) ref);
        sql_ = b;
        return b;
      } else {
        return (com.google.protobuf.ByteString) ref;
      }
    }

    public static final int OP_FIELD_NUMBER = 3;
    private int op_;
    /**
     * <code>.MetaDataOperation op = 3;</code>
     * @return The enum numeric value on the wire for op.
     */
    @java.lang.Override public int getOpValue() {
      return op_;
    }
    /**
     * <code>.MetaDataOperation op = 3;</code>
     * @return The op.
     */
    @java.lang.Override public org.apache.calcite.avatica.proto.Common.MetaDataOperation getOp() {
      @SuppressWarnings("deprecation")
      org.apache.calcite.avatica.proto.Common.MetaDataOperation result = org.apache.calcite.avatica.proto.Common.MetaDataOperation.valueOf(op_);
      return result == null ? org.apache.calcite.avatica.proto.Common.MetaDataOperation.UNRECOGNIZED : result;
    }

    public static final int ARGS_FIELD_NUMBER = 4;
    private java.util.List<org.apache.calcite.avatica.proto.Common.MetaDataOperationArgument> args_;
    /**
     * <code>repeated .MetaDataOperationArgument args = 4;</code>
     */
    @java.lang.Override
    public java.util.List<org.apache.calcite.avatica.proto.Common.MetaDataOperationArgument> getArgsList() {
      return args_;
    }
    /**
     * <code>repeated .MetaDataOperationArgument args = 4;</code>
     */
    @java.lang.Override
    public java.util.List<? extends org.apache.calcite.avatica.proto.Common.MetaDataOperationArgumentOrBuilder> 
        getArgsOrBuilderList() {
      return args_;
    }
    /**
     * <code>repeated .MetaDataOperationArgument args = 4;</code>
     */
    @java.lang.Override
    public int getArgsCount() {
      return args_.size();
    }
    /**
     * <code>repeated .MetaDataOperationArgument args = 4;</code>
     */
    @java.lang.Override
    public org.apache.calcite.avatica.proto.Common.MetaDataOperationArgument getArgs(int index) {
      return args_.get(index);
    }
    /**
     * <code>repeated .MetaDataOperationArgument args = 4;</code>
     */
    @java.lang.Override
    public org.apache.calcite.avatica.proto.Common.MetaDataOperationArgumentOrBuilder getArgsOrBuilder(
        int index) {
      return args_.get(index);
    }

    public static final int HAS_ARGS_FIELD_NUMBER = 5;
    private boolean hasArgs_;
    /**
     * <code>bool has_args = 5;</code>
     * @return The hasArgs.
     */
    @java.lang.Override
    public boolean getHasArgs() {
      return hasArgs_;
    }

    public static final int HAS_SQL_FIELD_NUMBER = 6;
    private boolean hasSql_;
    /**
     * <code>bool has_sql = 6;</code>
     * @return The hasSql.
     */
    @java.lang.Override
    public boolean getHasSql() {
      return hasSql_;
    }

    public static final int HAS_OP_FIELD_NUMBER = 7;
    private boolean hasOp_;
    /**
     * <code>bool has_op = 7;</code>
     * @return The hasOp.
     */
    @java.lang.Override
    public boolean getHasOp() {
      return hasOp_;
    }

    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 (type_ != org.apache.calcite.avatica.proto.Common.StateType.SQL.getNumber()) {
        output.writeEnum(1, type_);
      }
      if (!com.google.protobuf.GeneratedMessageV3.isStringEmpty(sql_)) {
        com.google.protobuf.GeneratedMessageV3.writeString(output, 2, sql_);
      }
      if (op_ != org.apache.calcite.avatica.proto.Common.MetaDataOperation.GET_ATTRIBUTES.getNumber()) {
        output.writeEnum(3, op_);
      }
      for (int i = 0; i < args_.size(); i++) {
        output.writeMessage(4, args_.get(i));
      }
      if (hasArgs_ != false) {
        output.writeBool(5, hasArgs_);
      }
      if (hasSql_ != false) {
        output.writeBool(6, hasSql_);
      }
      if (hasOp_ != false) {
        output.writeBool(7, hasOp_);
      }
      getUnknownFields().writeTo(output);
    }

    @java.lang.Override
    public int getSerializedSize() {
      int size = memoizedSize;
      if (size != -1) return size;

      size = 0;
      if (type_ != org.apache.calcite.avatica.proto.Common.StateType.SQL.getNumber()) {
        size += com.google.protobuf.CodedOutputStream
          .computeEnumSize(1, type_);
      }
      if (!com.google.protobuf.GeneratedMessageV3.isStringEmpty(sql_)) {
        size += com.google.protobuf.GeneratedMessageV3.computeStringSize(2, sql_);
      }
      if (op_ != org.apache.calcite.avatica.proto.Common.MetaDataOperation.GET_ATTRIBUTES.getNumber()) {
        size += com.google.protobuf.CodedOutputStream
          .computeEnumSize(3, op_);
      }
      for (int i = 0; i < args_.size(); i++) {
        size += com.google.protobuf.CodedOutputStream
          .computeMessageSize(4, args_.get(i));
      }
      if (hasArgs_ != false) {
        size += com.google.protobuf.CodedOutputStream
          .computeBoolSize(5, hasArgs_);
      }
      if (hasSql_ != false) {
        size += com.google.protobuf.CodedOutputStream
          .computeBoolSize(6, hasSql_);
      }
      if (hasOp_ != false) {
        size += com.google.protobuf.CodedOutputStream
          .computeBoolSize(7, hasOp_);
      }
      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 org.apache.calcite.avatica.proto.Common.QueryState)) {
        return super.equals(obj);
      }
      org.apache.calcite.avatica.proto.Common.QueryState other = (org.apache.calcite.avatica.proto.Common.QueryState) obj;

      if (type_ != other.type_) return false;
      if (!getSql()
          .equals(other.getSql())) return false;
      if (op_ != other.op_) return false;
      if (!getArgsList()
          .equals(other.getArgsList())) return false;
      if (getHasArgs()
          != other.getHasArgs()) return false;
      if (getHasSql()
          != other.getHasSql()) return false;
      if (getHasOp()
          != other.getHasOp()) 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();
      hash = (37 * hash) + TYPE_FIELD_NUMBER;
      hash = (53 * hash) + type_;
      hash = (37 * hash) + SQL_FIELD_NUMBER;
      hash = (53 * hash) + getSql().hashCode();
      hash = (37 * hash) + OP_FIELD_NUMBER;
      hash = (53 * hash) + op_;
      if (getArgsCount() > 0) {
        hash = (37 * hash) + ARGS_FIELD_NUMBER;
        hash = (53 * hash) + getArgsList().hashCode();
      }
      hash = (37 * hash) + HAS_ARGS_FIELD_NUMBER;
      hash = (53 * hash) + com.google.protobuf.Internal.hashBoolean(
          getHasArgs());
      hash = (37 * hash) + HAS_SQL_FIELD_NUMBER;
      hash = (53 * hash) + com.google.protobuf.Internal.hashBoolean(
          getHasSql());
      hash = (37 * hash) + HAS_OP_FIELD_NUMBER;
      hash = (53 * hash) + com.google.protobuf.Internal.hashBoolean(
          getHasOp());
      hash = (29 * hash) + getUnknownFields().hashCode();
      memoizedHashCode = hash;
      return hash;
    }

    public static org.apache.calcite.avatica.proto.Common.QueryState parseFrom(
        java.nio.ByteBuffer data)
        throws com.google.protobuf.InvalidProtocolBufferException {
      return PARSER.parseFrom(data);
    }
    public static org.apache.calcite.avatica.proto.Common.QueryState parseFrom(
        java.nio.ByteBuffer data,
        com.google.protobuf.ExtensionRegistryLite extensionRegistry)
        throws com.google.protobuf.InvalidProtocolBufferException {
      return PARSER.parseFrom(data, extensionRegistry);
    }
    public static org.apache.calcite.avatica.proto.Common.QueryState parseFrom(
        com.google.protobuf.ByteString data)
        throws com.google.protobuf.InvalidProtocolBufferException {
      return PARSER.parseFrom(data);
    }
    public static org.apache.calcite.avatica.proto.Common.QueryState parseFrom(
        com.google.protobuf.ByteString data,
        com.google.protobuf.ExtensionRegistryLite extensionRegistry)
        throws com.google.protobuf.InvalidProtocolBufferException {
      return PARSER.parseFrom(data, extensionRegistry);
    }
    public static org.apache.calcite.avatica.proto.Common.QueryState parseFrom(byte[] data)
        throws com.google.protobuf.InvalidProtocolBufferException {
      return PARSER.parseFrom(data);
    }
    public static org.apache.calcite.avatica.proto.Common.QueryState parseFrom(
        byte[] data,
        com.google.protobuf.ExtensionRegistryLite extensionRegistry)
        throws com.google.protobuf.InvalidProtocolBufferException {
      return PARSER.parseFrom(data, extensionRegistry);
    }
    public static org.apache.calcite.avatica.proto.Common.QueryState parseFrom(java.io.InputStream input)
        throws java.io.IOException {
      return com.google.protobuf.GeneratedMessageV3
          .parseWithIOException(PARSER, input);
    }
    public static org.apache.calcite.avatica.proto.Common.QueryState 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 org.apache.calcite.avatica.proto.Common.QueryState parseDelimitedFrom(java.io.InputStream input)
        throws java.io.IOException {
      return com.google.protobuf.GeneratedMessageV3
          .parseDelimitedWithIOException(PARSER, input);
    }
    public static org.apache.calcite.avatica.proto.Common.QueryState 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 org.apache.calcite.avatica.proto.Common.QueryState parseFrom(
        com.google.protobuf.CodedInputStream input)
        throws java.io.IOException {
      return com.google.protobuf.GeneratedMessageV3
          .parseWithIOException(PARSER, input);
    }
    public static org.apache.calcite.avatica.proto.Common.QueryState 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(org.apache.calcite.avatica.proto.Common.QueryState 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;
    }
    /**
     * Protobuf type {@code QueryState}
     */
    public static final class Builder extends
        com.google.protobuf.GeneratedMessageV3.Builder<Builder> implements
        // @@protoc_insertion_point(builder_implements:QueryState)
        org.apache.calcite.avatica.proto.Common.QueryStateOrBuilder {
      public static final com.google.protobuf.Descriptors.Descriptor
          getDescriptor() {
        return org.apache.calcite.avatica.proto.Common.internal_static_QueryState_descriptor;
      }

      @java.lang.Override
      protected com.google.protobuf.GeneratedMessageV3.FieldAccessorTable
          internalGetFieldAccessorTable() {
        return org.apache.calcite.avatica.proto.Common.internal_static_QueryState_fieldAccessorTable
            .ensureFieldAccessorsInitialized(
                org.apache.calcite.avatica.proto.Common.QueryState.class, org.apache.calcite.avatica.proto.Common.QueryState.Builder.class);
      }

      // Construct using org.apache.calcite.avatica.proto.Common.QueryState.newBuilder()
      private Builder() {

      }

      private Builder(
          com.google.protobuf.GeneratedMessageV3.BuilderParent parent) {
        super(parent);

      }
      @java.lang.Override
      public Builder clear() {
        super.clear();
        type_ = 0;

        sql_ = "";

        op_ = 0;

        if (argsBuilder_ == null) {
          args_ = java.util.Collections.emptyList();
        } else {
          args_ = null;
          argsBuilder_.clear();
        }
        bitField0_ = (bitField0_ & ~0x00000001);
        hasArgs_ = false;

        hasSql_ = false;

        hasOp_ = false;

        return this;
      }

      @java.lang.Override
      public com.google.protobuf.Descriptors.Descriptor
          getDescriptorForType() {
        return org.apache.calcite.avatica.proto.Common.internal_static_QueryState_descriptor;
      }

      @java.lang.Override
      public org.apache.calcite.avatica.proto.Common.QueryState getDefaultInstanceForType() {
        return org.apache.calcite.avatica.proto.Common.QueryState.getDefaultInstance();
      }

      @java.lang.Override
      public org.apache.calcite.avatica.proto.Common.QueryState build() {
        org.apache.calcite.avatica.proto.Common.QueryState result = buildPartial();
        if (!result.isInitialized()) {
          throw newUninitializedMessageException(result);
        }
        return result;
      }

      @java.lang.Override
      public org.apache.calcite.avatica.proto.Common.QueryState buildPartial() {
        org.apache.calcite.avatica.proto.Common.QueryState result = new org.apache.calcite.avatica.proto.Common.QueryState(this);
        int from_bitField0_ = bitField0_;
        result.type_ = type_;
        result.sql_ = sql_;
        result.op_ = op_;
        if (argsBuilder_ == null) {
          if (((bitField0_ & 0x00000001) != 0)) {
            args_ = java.util.Collections.unmodifiableList(args_);
            bitField0_ = (bitField0_ & ~0x00000001);
          }
          result.args_ = args_;
        } else {
          result.args_ = argsBuilder_.build();
        }
        result.hasArgs_ = hasArgs_;
        result.hasSql_ = hasSql_;
        result.hasOp_ = hasOp_;
        onBuilt();
        return result;
      }

      @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 org.apache.calcite.avatica.proto.Common.QueryState) {
          return mergeFrom((org.apache.calcite.avatica.proto.Common.QueryState)other);
        } else {
          super.mergeFrom(other);
          return this;
        }
      }

      public Builder mergeFrom(org.apache.calcite.avatica.proto.Common.QueryState other) {
        if (other == org.apache.calcite.avatica.proto.Common.QueryState.getDefaultInstance()) return this;
        if (other.type_ != 0) {
          setTypeValue(other.getTypeValue());
        }
        if (!other.getSql().isEmpty()) {
          sql_ = other.sql_;
          onChanged();
        }
        if (other.op_ != 0) {
          setOpValue(other.getOpValue());
        }
        if (argsBuilder_ == null) {
          if (!other.args_.isEmpty()) {
            if (args_.isEmpty()) {
              args_ = other.args_;
              bitField0_ = (bitField0_ & ~0x00000001);
            } else {
              ensureArgsIsMutable();
              args_.addAll(other.args_);
            }
            onChanged();
          }
        } else {
          if (!other.args_.isEmpty()) {
            if (argsBuilder_.isEmpty()) {
              argsBuilder_.dispose();
              argsBuilder_ = null;
              args_ = other.args_;
              bitField0_ = (bitField0_ & ~0x00000001);
              argsBuilder_ = 
                com.google.protobuf.GeneratedMessageV3.alwaysUseFieldBuilders ?
                   getArgsFieldBuilder() : null;
            } else {
              argsBuilder_.addAllMessages(other.args_);
            }
          }
        }
        if (other.getHasArgs() != false) {
          setHasArgs(other.getHasArgs());
        }
        if (other.getHasSql() != false) {
          setHasSql(other.getHasSql());
        }
        if (other.getHasOp() != false) {
          setHasOp(other.getHasOp());
        }
        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: {
                type_ = input.readEnum();

                break;
              } // case 8
              case 18: {
                sql_ = input.readStringRequireUtf8();

                break;
              } // case 18
              case 24: {
                op_ = input.readEnum();

                break;
              } // case 24
              case 34: {
                org.apache.calcite.avatica.proto.Common.MetaDataOperationArgument m =
                    input.readMessage(
                        org.apache.calcite.avatica.proto.Common.MetaDataOperationArgument.parser(),
                        extensionRegistry);
                if (argsBuilder_ == null) {
                  ensureArgsIsMutable();
                  args_.add(m);
                } else {
                  argsBuilder_.addMessage(m);
                }
                break;
              } // case 34
              case 40: {
                hasArgs_ = input.readBool();

                break;
              } // case 40
              case 48: {
                hasSql_ = input.readBool();

                break;
              } // case 48
              case 56: {
                hasOp_ = input.readBool();

                break;
              } // case 56
              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 type_ = 0;
      /**
       * <code>.StateType type = 1;</code>
       * @return The enum numeric value on the wire for type.
       */
      @java.lang.Override public int getTypeValue() {
        return type_;
      }
      /**
       * <code>.StateType type = 1;</code>
       * @param value The enum numeric value on the wire for type to set.
       * @return This builder for chaining.
       */
      public Builder setTypeValue(int value) {
        
        type_ = value;
        onChanged();
        return this;
      }
      /**
       * <code>.StateType type = 1;</code>
       * @return The type.
       */
      @java.lang.Override
      public org.apache.calcite.avatica.proto.Common.StateType getType() {
        @SuppressWarnings("deprecation")
        org.apache.calcite.avatica.proto.Common.StateType result = org.apache.calcite.avatica.proto.Common.StateType.valueOf(type_);
        return result == null ? org.apache.calcite.avatica.proto.Common.StateType.UNRECOGNIZED : result;
      }
      /**
       * <code>.StateType type = 1;</code>
       * @param value The type to set.
       * @return This builder for chaining.
       */
      public Builder setType(org.apache.calcite.avatica.proto.Common.StateType value) {
        if (value == null) {
          throw new NullPointerException();
        }
        
        type_ = value.getNumber();
        onChanged();
        return this;
      }
      /**
       * <code>.StateType type = 1;</code>
       * @return This builder for chaining.
       */
      public Builder clearType() {
        
        type_ = 0;
        onChanged();
        return this;
      }

      private java.lang.Object sql_ = "";
      /**
       * <code>string sql = 2;</code>
       * @return The sql.
       */
      public java.lang.String getSql() {
        java.lang.Object ref = sql_;
        if (!(ref instanceof java.lang.String)) {
          com.google.protobuf.ByteString bs =
              (com.google.protobuf.ByteString) ref;
          java.lang.String s = bs.toStringUtf8();
          sql_ = s;
          return s;
        } else {
          return (java.lang.String) ref;
        }
      }
      /**
       * <code>string sql = 2;</code>
       * @return The bytes for sql.
       */
      public com.google.protobuf.ByteString
          getSqlBytes() {
        java.lang.Object ref = sql_;
        if (ref instanceof String) {
          com.google.protobuf.ByteString b = 
              com.google.protobuf.ByteString.copyFromUtf8(
                  (java.lang.String) ref);
          sql_ = b;
          return b;
        } else {
          return (com.google.protobuf.ByteString) ref;
        }
      }
      /**
       * <code>string sql = 2;</code>
       * @param value The sql to set.
       * @return This builder for chaining.
       */
      public Builder setSql(
          java.lang.String value) {
        if (value == null) {
    throw new NullPointerException();
  }
  
        sql_ = value;
        onChanged();
        return this;
      }
      /**
       * <code>string sql = 2;</code>
       * @return This builder for chaining.
       */
      public Builder clearSql() {
        
        sql_ = getDefaultInstance().getSql();
        onChanged();
        return this;
      }
      /**
       * <code>string sql = 2;</code>
       * @param value The bytes for sql to set.
       * @return This builder for chaining.
       */
      public Builder setSqlBytes(
          com.google.protobuf.ByteString value) {
        if (value == null) {
    throw new NullPointerException();
  }
  checkByteStringIsUtf8(value);
        
        sql_ = value;
        onChanged();
        return this;
      }

      private int op_ = 0;
      /**
       * <code>.MetaDataOperation op = 3;</code>
       * @return The enum numeric value on the wire for op.
       */
      @java.lang.Override public int getOpValue() {
        return op_;
      }
      /**
       * <code>.MetaDataOperation op = 3;</code>
       * @param value The enum numeric value on the wire for op to set.
       * @return This builder for chaining.
       */
      public Builder setOpValue(int value) {
        
        op_ = value;
        onChanged();
        return this;
      }
      /**
       * <code>.MetaDataOperation op = 3;</code>
       * @return The op.
       */
      @java.lang.Override
      public org.apache.calcite.avatica.proto.Common.MetaDataOperation getOp() {
        @SuppressWarnings("deprecation")
        org.apache.calcite.avatica.proto.Common.MetaDataOperation result = org.apache.calcite.avatica.proto.Common.MetaDataOperation.valueOf(op_);
        return result == null ? org.apache.calcite.avatica.proto.Common.MetaDataOperation.UNRECOGNIZED : result;
      }
      /**
       * <code>.MetaDataOperation op = 3;</code>
       * @param value The op to set.
       * @return This builder for chaining.
       */
      public Builder setOp(org.apache.calcite.avatica.proto.Common.MetaDataOperation value) {
        if (value == null) {
          throw new NullPointerException();
        }
        
        op_ = value.getNumber();
        onChanged();
        return this;
      }
      /**
       * <code>.MetaDataOperation op = 3;</code>
       * @return This builder for chaining.
       */
      public Builder clearOp() {
        
        op_ = 0;
        onChanged();
        return this;
      }

      private java.util.List<org.apache.calcite.avatica.proto.Common.MetaDataOperationArgument> args_ =
        java.util.Collections.emptyList();
      private void ensureArgsIsMutable() {
        if (!((bitField0_ & 0x00000001) != 0)) {
          args_ = new java.util.ArrayList<org.apache.calcite.avatica.proto.Common.MetaDataOperationArgument>(args_);
          bitField0_ |= 0x00000001;
         }
      }

      private com.google.protobuf.RepeatedFieldBuilderV3<
          org.apache.calcite.avatica.proto.Common.MetaDataOperationArgument, org.apache.calcite.avatica.proto.Common.MetaDataOperationArgument.Builder, org.apache.calcite.avatica.proto.Common.MetaDataOperationArgumentOrBuilder> argsBuilder_;

      /**
       * <code>repeated .MetaDataOperationArgument args = 4;</code>
       */
      public java.util.List<org.apache.calcite.avatica.proto.Common.MetaDataOperationArgument> getArgsList() {
        if (argsBuilder_ == null) {
          return java.util.Collections.unmodifiableList(args_);
        } else {
          return argsBuilder_.getMessageList();
        }
      }
      /**
       * <code>repeated .MetaDataOperationArgument args = 4;</code>
       */
      public int getArgsCount() {
        if (argsBuilder_ == null) {
          return args_.size();
        } else {
          return argsBuilder_.getCount();
        }
      }
      /**
       * <code>repeated .MetaDataOperationArgument args = 4;</code>
       */
      public org.apache.calcite.avatica.proto.Common.MetaDataOperationArgument getArgs(int index) {
        if (argsBuilder_ == null) {
          return args_.get(index);
        } else {
          return argsBuilder_.getMessage(index);
        }
      }
      /**
       * <code>repeated .MetaDataOperationArgument args = 4;</code>
       */
      public Builder setArgs(
          int index, org.apache.calcite.avatica.proto.Common.MetaDataOperationArgument value) {
        if (argsBuilder_ == null) {
          if (value == null) {
            throw new NullPointerException();
          }
          ensureArgsIsMutable();
          args_.set(index, value);
          onChanged();
        } else {
          argsBuilder_.setMessage(index, value);
        }
        return this;
      }
      /**
       * <code>repeated .MetaDataOperationArgument args = 4;</code>
       */
      public Builder setArgs(
          int index, org.apache.calcite.avatica.proto.Common.MetaDataOperationArgument.Builder builderForValue) {
        if (argsBuilder_ == null) {
          ensureArgsIsMutable();
          args_.set(index, builderForValue.build());
          onChanged();
        } else {
          argsBuilder_.setMessage(index, builderForValue.build());
        }
        return this;
      }
      /**
       * <code>repeated .MetaDataOperationArgument args = 4;</code>
       */
      public Builder addArgs(org.apache.calcite.avatica.proto.Common.MetaDataOperationArgument value) {
        if (argsBuilder_ == null) {
          if (value == null) {
            throw new NullPointerException();
          }
          ensureArgsIsMutable();
          args_.add(value);
          onChanged();
        } else {
          argsBuilder_.addMessage(value);
        }
        return this;
      }
      /**
       * <code>repeated .MetaDataOperationArgument args = 4;</code>
       */
      public Builder addArgs(
          int index, org.apache.calcite.avatica.proto.Common.MetaDataOperationArgument value) {
        if (argsBuilder_ == null) {
          if (value == null) {
            throw new NullPointerException();
          }
          ensureArgsIsMutable();
          args_.add(index, value);
          onChanged();
        } else {
          argsBuilder_.addMessage(index, value);
        }
        return this;
      }
      /**
       * <code>repeated .MetaDataOperationArgument args = 4;</code>
       */
      public Builder addArgs(
          org.apache.calcite.avatica.proto.Common.MetaDataOperationArgument.Builder builderForValue) {
        if (argsBuilder_ == null) {
          ensureArgsIsMutable();
          args_.add(builderForValue.build());
          onChanged();
        } else {
          argsBuilder_.addMessage(builderForValue.build());
        }
        return this;
      }
      /**
       * <code>repeated .MetaDataOperationArgument args = 4;</code>
       */
      public Builder addArgs(
          int index, org.apache.calcite.avatica.proto.Common.MetaDataOperationArgument.Builder builderForValue) {
        if (argsBuilder_ == null) {
          ensureArgsIsMutable();
          args_.add(index, builderForValue.build());
          onChanged();
        } else {
          argsBuilder_.addMessage(index, builderForValue.build());
        }
        return this;
      }
      /**
       * <code>repeated .MetaDataOperationArgument args = 4;</code>
       */
      public Builder addAllArgs(
          java.lang.Iterable<? extends org.apache.calcite.avatica.proto.Common.MetaDataOperationArgument> values) {
        if (argsBuilder_ == null) {
          ensureArgsIsMutable();
          com.google.protobuf.AbstractMessageLite.Builder.addAll(
              values, args_);
          onChanged();
        } else {
          argsBuilder_.addAllMessages(values);
        }
        return this;
      }
      /**
       * <code>repeated .MetaDataOperationArgument args = 4;</code>
       */
      public Builder clearArgs() {
        if (argsBuilder_ == null) {
          args_ = java.util.Collections.emptyList();
          bitField0_ = (bitField0_ & ~0x00000001);
          onChanged();
        } else {
          argsBuilder_.clear();
        }
        return this;
      }
      /**
       * <code>repeated .MetaDataOperationArgument args = 4;</code>
       */
      public Builder removeArgs(int index) {
        if (argsBuilder_ == null) {
          ensureArgsIsMutable();
          args_.remove(index);
          onChanged();
        } else {
          argsBuilder_.remove(index);
        }
        return this;
      }
      /**
       * <code>repeated .MetaDataOperationArgument args = 4;</code>
       */
      public org.apache.calcite.avatica.proto.Common.MetaDataOperationArgument.Builder getArgsBuilder(
          int index) {
        return getArgsFieldBuilder().getBuilder(index);
      }
      /**
       * <code>repeated .MetaDataOperationArgument args = 4;</code>
       */
      public org.apache.calcite.avatica.proto.Common.MetaDataOperationArgumentOrBuilder getArgsOrBuilder(
          int index) {
        if (argsBuilder_ == null) {
          return args_.get(index);  } else {
          return argsBuilder_.getMessageOrBuilder(index);
        }
      }
      /**
       * <code>repeated .MetaDataOperationArgument args = 4;</code>
       */
      public java.util.List<? extends org.apache.calcite.avatica.proto.Common.MetaDataOperationArgumentOrBuilder> 
           getArgsOrBuilderList() {
        if (argsBuilder_ != null) {
          return argsBuilder_.getMessageOrBuilderList();
        } else {
          return java.util.Collections.unmodifiableList(args_);
        }
      }
      /**
       * <code>repeated .MetaDataOperationArgument args = 4;</code>
       */
      public org.apache.calcite.avatica.proto.Common.MetaDataOperationArgument.Builder addArgsBuilder() {
        return getArgsFieldBuilder().addBuilder(
            org.apache.calcite.avatica.proto.Common.MetaDataOperationArgument.getDefaultInstance());
      }
      /**
       * <code>repeated .MetaDataOperationArgument args = 4;</code>
       */
      public org.apache.calcite.avatica.proto.Common.MetaDataOperationArgument.Builder addArgsBuilder(
          int index) {
        return getArgsFieldBuilder().addBuilder(
            index, org.apache.calcite.avatica.proto.Common.MetaDataOperationArgument.getDefaultInstance());
      }
      /**
       * <code>repeated .MetaDataOperationArgument args = 4;</code>
       */
      public java.util.List<org.apache.calcite.avatica.proto.Common.MetaDataOperationArgument.Builder> 
           getArgsBuilderList() {
        return getArgsFieldBuilder().getBuilderList();
      }
      private com.google.protobuf.RepeatedFieldBuilderV3<
          org.apache.calcite.avatica.proto.Common.MetaDataOperationArgument, org.apache.calcite.avatica.proto.Common.MetaDataOperationArgument.Builder, org.apache.calcite.avatica.proto.Common.MetaDataOperationArgumentOrBuilder> 
          getArgsFieldBuilder() {
        if (argsBuilder_ == null) {
          argsBuilder_ = new com.google.protobuf.RepeatedFieldBuilderV3<
              org.apache.calcite.avatica.proto.Common.MetaDataOperationArgument, org.apache.calcite.avatica.proto.Common.MetaDataOperationArgument.Builder, org.apache.calcite.avatica.proto.Common.MetaDataOperationArgumentOrBuilder>(
                  args_,
                  ((bitField0_ & 0x00000001) != 0),
                  getParentForChildren(),
                  isClean());
          args_ = null;
        }
        return argsBuilder_;
      }

      private boolean hasArgs_ ;
      /**
       * <code>bool has_args = 5;</code>
       * @return The hasArgs.
       */
      @java.lang.Override
      public boolean getHasArgs() {
        return hasArgs_;
      }
      /**
       * <code>bool has_args = 5;</code>
       * @param value The hasArgs to set.
       * @return This builder for chaining.
       */
      public Builder setHasArgs(boolean value) {
        
        hasArgs_ = value;
        onChanged();
        return this;
      }
      /**
       * <code>bool has_args = 5;</code>
       * @return This builder for chaining.
       */
      public Builder clearHasArgs() {
        
        hasArgs_ = false;
        onChanged();
        return this;
      }

      private boolean hasSql_ ;
      /**
       * <code>bool has_sql = 6;</code>
       * @return The hasSql.
       */
      @java.lang.Override
      public boolean getHasSql() {
        return hasSql_;
      }
      /**
       * <code>bool has_sql = 6;</code>
       * @param value The hasSql to set.
       * @return This builder for chaining.
       */
      public Builder setHasSql(boolean value) {
        
        hasSql_ = value;
        onChanged();
        return this;
      }
      /**
       * <code>bool has_sql = 6;</code>
       * @return This builder for chaining.
       */
      public Builder clearHasSql() {
        
        hasSql_ = false;
        onChanged();
        return this;
      }

      private boolean hasOp_ ;
      /**
       * <code>bool has_op = 7;</code>
       * @return The hasOp.
       */
      @java.lang.Override
      public boolean getHasOp() {
        return hasOp_;
      }
      /**
       * <code>bool has_op = 7;</code>
       * @param value The hasOp to set.
       * @return This builder for chaining.
       */
      public Builder setHasOp(boolean value) {
        
        hasOp_ = value;
        onChanged();
        return this;
      }
      /**
       * <code>bool has_op = 7;</code>
       * @return This builder for chaining.
       */
      public Builder clearHasOp() {
        
        hasOp_ = false;
        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:QueryState)
    }

    // @@protoc_insertion_point(class_scope:QueryState)
    private static final org.apache.calcite.avatica.proto.Common.QueryState DEFAULT_INSTANCE;
    static {
      DEFAULT_INSTANCE = new org.apache.calcite.avatica.proto.Common.QueryState();
    }

    public static org.apache.calcite.avatica.proto.Common.QueryState getDefaultInstance() {
      return DEFAULT_INSTANCE;
    }

    private static final com.google.protobuf.Parser<QueryState>
        PARSER = new com.google.protobuf.AbstractParser<QueryState>() {
      @java.lang.Override
      public QueryState 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<QueryState> parser() {
      return PARSER;
    }

    @java.lang.Override
    public com.google.protobuf.Parser<QueryState> getParserForType() {
      return PARSER;
    }

    @java.lang.Override
    public org.apache.calcite.avatica.proto.Common.QueryState getDefaultInstanceForType() {
      return DEFAULT_INSTANCE;
    }

  }

  private static final com.google.protobuf.Descriptors.Descriptor
    internal_static_ConnectionProperties_descriptor;
  private static final 
    com.google.protobuf.GeneratedMessageV3.FieldAccessorTable
      internal_static_ConnectionProperties_fieldAccessorTable;
  private static final com.google.protobuf.Descriptors.Descriptor
    internal_static_StatementHandle_descriptor;
  private static final 
    com.google.protobuf.GeneratedMessageV3.FieldAccessorTable
      internal_static_StatementHandle_fieldAccessorTable;
  private static final com.google.protobuf.Descriptors.Descriptor
    internal_static_Signature_descriptor;
  private static final 
    com.google.protobuf.GeneratedMessageV3.FieldAccessorTable
      internal_static_Signature_fieldAccessorTable;
  private static final com.google.protobuf.Descriptors.Descriptor
    internal_static_ColumnMetaData_descriptor;
  private static final 
    com.google.protobuf.GeneratedMessageV3.FieldAccessorTable
      internal_static_ColumnMetaData_fieldAccessorTable;
  private static final com.google.protobuf.Descriptors.Descriptor
    internal_static_AvaticaType_descriptor;
  private static final 
    com.google.protobuf.GeneratedMessageV3.FieldAccessorTable
      internal_static_AvaticaType_fieldAccessorTable;
  private static final com.google.protobuf.Descriptors.Descriptor
    internal_static_AvaticaParameter_descriptor;
  private static final 
    com.google.protobuf.GeneratedMessageV3.FieldAccessorTable
      internal_static_AvaticaParameter_fieldAccessorTable;
  private static final com.google.protobuf.Descriptors.Descriptor
    internal_static_CursorFactory_descriptor;
  private static final 
    com.google.protobuf.GeneratedMessageV3.FieldAccessorTable
      internal_static_CursorFactory_fieldAccessorTable;
  private static final com.google.protobuf.Descriptors.Descriptor
    internal_static_Frame_descriptor;
  private static final 
    com.google.protobuf.GeneratedMessageV3.FieldAccessorTable
      internal_static_Frame_fieldAccessorTable;
  private static final com.google.protobuf.Descriptors.Descriptor
    internal_static_Row_descriptor;
  private static final 
    com.google.protobuf.GeneratedMessageV3.FieldAccessorTable
      internal_static_Row_fieldAccessorTable;
  private static final com.google.protobuf.Descriptors.Descriptor
    internal_static_DatabaseProperty_descriptor;
  private static final 
    com.google.protobuf.GeneratedMessageV3.FieldAccessorTable
      internal_static_DatabaseProperty_fieldAccessorTable;
  private static final com.google.protobuf.Descriptors.Descriptor
    internal_static_WireMessage_descriptor;
  private static final 
    com.google.protobuf.GeneratedMessageV3.FieldAccessorTable
      internal_static_WireMessage_fieldAccessorTable;
  private static final com.google.protobuf.Descriptors.Descriptor
    internal_static_ColumnValue_descriptor;
  private static final 
    com.google.protobuf.GeneratedMessageV3.FieldAccessorTable
      internal_static_ColumnValue_fieldAccessorTable;
  private static final com.google.protobuf.Descriptors.Descriptor
    internal_static_TypedValue_descriptor;
  private static final 
    com.google.protobuf.GeneratedMessageV3.FieldAccessorTable
      internal_static_TypedValue_fieldAccessorTable;
  private static final com.google.protobuf.Descriptors.Descriptor
    internal_static_MetaDataOperationArgument_descriptor;
  private static final 
    com.google.protobuf.GeneratedMessageV3.FieldAccessorTable
      internal_static_MetaDataOperationArgument_fieldAccessorTable;
  private static final com.google.protobuf.Descriptors.Descriptor
    internal_static_QueryState_descriptor;
  private static final 
    com.google.protobuf.GeneratedMessageV3.FieldAccessorTable
      internal_static_QueryState_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\014common.proto\"\300\001\n\024ConnectionProperties\022" +
      "\020\n\010is_dirty\030\001 \001(\010\022\023\n\013auto_commit\030\002 \001(\010\022\027" +
      "\n\017has_auto_commit\030\007 \001(\010\022\021\n\tread_only\030\003 \001" +
      "(\010\022\025\n\rhas_read_only\030\010 \001(\010\022\035\n\025transaction" +
      "_isolation\030\004 \001(\r\022\017\n\007catalog\030\005 \001(\t\022\016\n\006sch" +
      "ema\030\006 \001(\t\"S\n\017StatementHandle\022\025\n\rconnecti" +
      "on_id\030\001 \001(\t\022\n\n\002id\030\002 \001(\r\022\035\n\tsignature\030\003 \001" +
      "(\0132\n.Signature\"\260\001\n\tSignature\022 \n\007columns\030" +
      "\001 \003(\0132\017.ColumnMetaData\022\013\n\003sql\030\002 \001(\t\022%\n\np" +
      "arameters\030\003 \003(\0132\021.AvaticaParameter\022&\n\016cu" +
      "rsor_factory\030\004 \001(\0132\016.CursorFactory\022%\n\rst" +
      "atementType\030\005 \001(\0162\016.StatementType\"\255\003\n\016Co" +
      "lumnMetaData\022\017\n\007ordinal\030\001 \001(\r\022\026\n\016auto_in" +
      "crement\030\002 \001(\010\022\026\n\016case_sensitive\030\003 \001(\010\022\022\n" +
      "\nsearchable\030\004 \001(\010\022\020\n\010currency\030\005 \001(\010\022\020\n\010n" +
      "ullable\030\006 \001(\r\022\016\n\006signed\030\007 \001(\010\022\024\n\014display" +
      "_size\030\010 \001(\r\022\r\n\005label\030\t \001(\t\022\023\n\013column_nam" +
      "e\030\n \001(\t\022\023\n\013schema_name\030\013 \001(\t\022\021\n\tprecisio" +
      "n\030\014 \001(\r\022\r\n\005scale\030\r \001(\r\022\022\n\ntable_name\030\016 \001" +
      "(\t\022\024\n\014catalog_name\030\017 \001(\t\022\021\n\tread_only\030\020 " +
      "\001(\010\022\020\n\010writable\030\021 \001(\010\022\033\n\023definitely_writ" +
      "able\030\022 \001(\010\022\031\n\021column_class_name\030\023 \001(\t\022\032\n" +
      "\004type\030\024 \001(\0132\014.AvaticaType\"}\n\013AvaticaType" +
      "\022\n\n\002id\030\001 \001(\r\022\014\n\004name\030\002 \001(\t\022\021\n\003rep\030\003 \001(\0162" +
      "\004.Rep\022 \n\007columns\030\004 \003(\0132\017.ColumnMetaData\022" +
      "\037\n\tcomponent\030\005 \001(\0132\014.AvaticaType\"\221\001\n\020Ava" +
      "ticaParameter\022\016\n\006signed\030\001 \001(\010\022\021\n\tprecisi" +
      "on\030\002 \001(\r\022\r\n\005scale\030\003 \001(\r\022\026\n\016parameter_typ" +
      "e\030\004 \001(\r\022\021\n\ttype_name\030\005 \001(\t\022\022\n\nclass_name" +
      "\030\006 \001(\t\022\014\n\004name\030\007 \001(\t\"\263\001\n\rCursorFactory\022#" +
      "\n\005style\030\001 \001(\0162\024.CursorFactory.Style\022\022\n\nc" +
      "lass_name\030\002 \001(\t\022\023\n\013field_names\030\003 \003(\t\"T\n\005" +
      "Style\022\n\n\006OBJECT\020\000\022\n\n\006RECORD\020\001\022\025\n\021RECORD_" +
      "PROJECTION\020\002\022\t\n\005ARRAY\020\003\022\010\n\004LIST\020\004\022\007\n\003MAP" +
      "\020\005\"9\n\005Frame\022\016\n\006offset\030\001 \001(\004\022\014\n\004done\030\002 \001(" +
      "\010\022\022\n\004rows\030\003 \003(\0132\004.Row\"\"\n\003Row\022\033\n\005value\030\001 " +
      "\003(\0132\014.ColumnValue\"3\n\020DatabaseProperty\022\014\n" +
      "\004name\030\001 \001(\t\022\021\n\tfunctions\030\002 \003(\t\"4\n\013WireMe" +
      "ssage\022\014\n\004name\030\001 \001(\t\022\027\n\017wrapped_message\030\002" +
      " \001(\014\"\207\001\n\013ColumnValue\022\032\n\005value\030\001 \003(\0132\013.Ty" +
      "pedValue\022 \n\013array_value\030\002 \003(\0132\013.TypedVal" +
      "ue\022\027\n\017has_array_value\030\003 \001(\010\022!\n\014scalar_va" +
      "lue\030\004 \001(\0132\013.TypedValue\"\362\001\n\nTypedValue\022\022\n" +
      "\004type\030\001 \001(\0162\004.Rep\022\022\n\nbool_value\030\002 \001(\010\022\024\n" +
      "\014string_value\030\003 \001(\t\022\024\n\014number_value\030\004 \001(" +
      "\022\022\023\n\013bytes_value\030\005 \001(\014\022\024\n\014double_value\030\006" +
      " \001(\001\022\014\n\004null\030\007 \001(\010\022 \n\013array_value\030\010 \003(\0132" +
      "\013.TypedValue\022\034\n\016component_type\030\t \001(\0162\004.R" +
      "ep\022\027\n\017implicitly_null\030\n \001(\010\"\246\002\n\031MetaData" +
      "OperationArgument\022\024\n\014string_value\030\001 \001(\t\022" +
      "\022\n\nbool_value\030\002 \001(\010\022\021\n\tint_value\030\003 \001(\021\022\033" +
      "\n\023string_array_values\030\004 \003(\t\022\030\n\020int_array" +
      "_values\030\005 \003(\021\0225\n\004type\030\006 \001(\0162\'.MetaDataOp" +
      "erationArgument.ArgumentType\"^\n\014Argument" +
      "Type\022\n\n\006STRING\020\000\022\010\n\004BOOL\020\001\022\007\n\003INT\020\002\022\023\n\017R" +
      "EPEATED_STRING\020\003\022\020\n\014REPEATED_INT\020\004\022\010\n\004NU" +
      "LL\020\005\"\260\001\n\nQueryState\022\030\n\004type\030\001 \001(\0162\n.Stat" +
      "eType\022\013\n\003sql\030\002 \001(\t\022\036\n\002op\030\003 \001(\0162\022.MetaDat" +
      "aOperation\022(\n\004args\030\004 \003(\0132\032.MetaDataOpera" +
      "tionArgument\022\020\n\010has_args\030\005 \001(\010\022\017\n\007has_sq" +
      "l\030\006 \001(\010\022\016\n\006has_op\030\007 \001(\010*\237\001\n\rStatementTyp" +
      "e\022\n\n\006SELECT\020\000\022\n\n\006INSERT\020\001\022\n\n\006UPDATE\020\002\022\n\n" +
      "\006DELETE\020\003\022\n\n\006UPSERT\020\004\022\t\n\005MERGE\020\005\022\r\n\tOTHE" +
      "R_DML\020\006\022\n\n\006CREATE\020\007\022\010\n\004DROP\020\010\022\t\n\005ALTER\020\t" +
      "\022\r\n\tOTHER_DDL\020\n\022\010\n\004CALL\020\013*\342\003\n\003Rep\022\025\n\021PRI" +
      "MITIVE_BOOLEAN\020\000\022\022\n\016PRIMITIVE_BYTE\020\001\022\022\n\016" +
      "PRIMITIVE_CHAR\020\002\022\023\n\017PRIMITIVE_SHORT\020\003\022\021\n" +
      "\rPRIMITIVE_INT\020\004\022\022\n\016PRIMITIVE_LONG\020\005\022\023\n\017" +
      "PRIMITIVE_FLOAT\020\006\022\024\n\020PRIMITIVE_DOUBLE\020\007\022" +
      "\013\n\007BOOLEAN\020\010\022\010\n\004BYTE\020\t\022\r\n\tCHARACTER\020\n\022\t\n" +
      "\005SHORT\020\013\022\013\n\007INTEGER\020\014\022\010\n\004LONG\020\r\022\t\n\005FLOAT" +
      "\020\016\022\n\n\006DOUBLE\020\017\022\017\n\013BIG_INTEGER\020\031\022\017\n\013BIG_D" +
      "ECIMAL\020\032\022\021\n\rJAVA_SQL_TIME\020\020\022\026\n\022JAVA_SQL_" +
      "TIMESTAMP\020\021\022\021\n\rJAVA_SQL_DATE\020\022\022\022\n\016JAVA_U" +
      "TIL_DATE\020\023\022\017\n\013BYTE_STRING\020\024\022\n\n\006STRING\020\025\022" +
      "\n\n\006NUMBER\020\026\022\n\n\006OBJECT\020\027\022\010\n\004NULL\020\030\022\t\n\005ARR" +
      "AY\020\033\022\n\n\006STRUCT\020\034\022\014\n\010MULTISET\020\035*^\n\010Severi" +
      "ty\022\024\n\020UNKNOWN_SEVERITY\020\000\022\022\n\016FATAL_SEVERI" +
      "TY\020\001\022\022\n\016ERROR_SEVERITY\020\002\022\024\n\020WARNING_SEVE" +
      "RITY\020\003*\327\004\n\021MetaDataOperation\022\022\n\016GET_ATTR" +
      "IBUTES\020\000\022\033\n\027GET_BEST_ROW_IDENTIFIER\020\001\022\020\n" +
      "\014GET_CATALOGS\020\002\022\036\n\032GET_CLIENT_INFO_PROPE" +
      "RTIES\020\003\022\031\n\025GET_COLUMN_PRIVILEGES\020\004\022\017\n\013GE" +
      "T_COLUMNS\020\005\022\027\n\023GET_CROSS_REFERENCE\020\006\022\025\n\021" +
      "GET_EXPORTED_KEYS\020\007\022\030\n\024GET_FUNCTION_COLU" +
      "MNS\020\010\022\021\n\rGET_FUNCTIONS\020\t\022\025\n\021GET_IMPORTED" +
      "_KEYS\020\n\022\022\n\016GET_INDEX_INFO\020\013\022\024\n\020GET_PRIMA" +
      "RY_KEYS\020\014\022\031\n\025GET_PROCEDURE_COLUMNS\020\r\022\022\n\016" +
      "GET_PROCEDURES\020\016\022\026\n\022GET_PSEUDO_COLUMNS\020\017" +
      "\022\017\n\013GET_SCHEMAS\020\020\022\031\n\025GET_SCHEMAS_WITH_AR" +
      "GS\020\021\022\024\n\020GET_SUPER_TABLES\020\022\022\023\n\017GET_SUPER_" +
      "TYPES\020\023\022\030\n\024GET_TABLE_PRIVILEGES\020\024\022\016\n\nGET" +
      "_TABLES\020\025\022\023\n\017GET_TABLE_TYPES\020\026\022\021\n\rGET_TY" +
      "PE_INFO\020\027\022\014\n\010GET_UDTS\020\030\022\027\n\023GET_VERSION_C" +
      "OLUMNS\020\031*\"\n\tStateType\022\007\n\003SQL\020\000\022\014\n\010METADA" +
      "TA\020\001B\"\n org.apache.calcite.avatica.proto" +
      "b\006proto3"
    };
    descriptor = com.google.protobuf.Descriptors.FileDescriptor
      .internalBuildGeneratedFileFrom(descriptorData,
        new com.google.protobuf.Descriptors.FileDescriptor[] {
        });
    internal_static_ConnectionProperties_descriptor =
      getDescriptor().getMessageTypes().get(0);
    internal_static_ConnectionProperties_fieldAccessorTable = new
      com.google.protobuf.GeneratedMessageV3.FieldAccessorTable(
        internal_static_ConnectionProperties_descriptor,
        new java.lang.String[] { "IsDirty", "AutoCommit", "HasAutoCommit", "ReadOnly", "HasReadOnly", "TransactionIsolation", "Catalog", "Schema", });
    internal_static_StatementHandle_descriptor =
      getDescriptor().getMessageTypes().get(1);
    internal_static_StatementHandle_fieldAccessorTable = new
      com.google.protobuf.GeneratedMessageV3.FieldAccessorTable(
        internal_static_StatementHandle_descriptor,
        new java.lang.String[] { "ConnectionId", "Id", "Signature", });
    internal_static_Signature_descriptor =
      getDescriptor().getMessageTypes().get(2);
    internal_static_Signature_fieldAccessorTable = new
      com.google.protobuf.GeneratedMessageV3.FieldAccessorTable(
        internal_static_Signature_descriptor,
        new java.lang.String[] { "Columns", "Sql", "Parameters", "CursorFactory", "StatementType", });
    internal_static_ColumnMetaData_descriptor =
      getDescriptor().getMessageTypes().get(3);
    internal_static_ColumnMetaData_fieldAccessorTable = new
      com.google.protobuf.GeneratedMessageV3.FieldAccessorTable(
        internal_static_ColumnMetaData_descriptor,
        new java.lang.String[] { "Ordinal", "AutoIncrement", "CaseSensitive", "Searchable", "Currency", "Nullable", "Signed", "DisplaySize", "Label", "ColumnName", "SchemaName", "Precision", "Scale", "TableName", "CatalogName", "ReadOnly", "Writable", "DefinitelyWritable", "ColumnClassName", "Type", });
    internal_static_AvaticaType_descriptor =
      getDescriptor().getMessageTypes().get(4);
    internal_static_AvaticaType_fieldAccessorTable = new
      com.google.protobuf.GeneratedMessageV3.FieldAccessorTable(
        internal_static_AvaticaType_descriptor,
        new java.lang.String[] { "Id", "Name", "Rep", "Columns", "Component", });
    internal_static_AvaticaParameter_descriptor =
      getDescriptor().getMessageTypes().get(5);
    internal_static_AvaticaParameter_fieldAccessorTable = new
      com.google.protobuf.GeneratedMessageV3.FieldAccessorTable(
        internal_static_AvaticaParameter_descriptor,
        new java.lang.String[] { "Signed", "Precision", "Scale", "ParameterType", "TypeName", "ClassName", "Name", });
    internal_static_CursorFactory_descriptor =
      getDescriptor().getMessageTypes().get(6);
    internal_static_CursorFactory_fieldAccessorTable = new
      com.google.protobuf.GeneratedMessageV3.FieldAccessorTable(
        internal_static_CursorFactory_descriptor,
        new java.lang.String[] { "Style", "ClassName", "FieldNames", });
    internal_static_Frame_descriptor =
      getDescriptor().getMessageTypes().get(7);
    internal_static_Frame_fieldAccessorTable = new
      com.google.protobuf.GeneratedMessageV3.FieldAccessorTable(
        internal_static_Frame_descriptor,
        new java.lang.String[] { "Offset", "Done", "Rows", });
    internal_static_Row_descriptor =
      getDescriptor().getMessageTypes().get(8);
    internal_static_Row_fieldAccessorTable = new
      com.google.protobuf.GeneratedMessageV3.FieldAccessorTable(
        internal_static_Row_descriptor,
        new java.lang.String[] { "Value", });
    internal_static_DatabaseProperty_descriptor =
      getDescriptor().getMessageTypes().get(9);
    internal_static_DatabaseProperty_fieldAccessorTable = new
      com.google.protobuf.GeneratedMessageV3.FieldAccessorTable(
        internal_static_DatabaseProperty_descriptor,
        new java.lang.String[] { "Name", "Functions", });
    internal_static_WireMessage_descriptor =
      getDescriptor().getMessageTypes().get(10);
    internal_static_WireMessage_fieldAccessorTable = new
      com.google.protobuf.GeneratedMessageV3.FieldAccessorTable(
        internal_static_WireMessage_descriptor,
        new java.lang.String[] { "Name", "WrappedMessage", });
    internal_static_ColumnValue_descriptor =
      getDescriptor().getMessageTypes().get(11);
    internal_static_ColumnValue_fieldAccessorTable = new
      com.google.protobuf.GeneratedMessageV3.FieldAccessorTable(
        internal_static_ColumnValue_descriptor,
        new java.lang.String[] { "Value", "ArrayValue", "HasArrayValue", "ScalarValue", });
    internal_static_TypedValue_descriptor =
      getDescriptor().getMessageTypes().get(12);
    internal_static_TypedValue_fieldAccessorTable = new
      com.google.protobuf.GeneratedMessageV3.FieldAccessorTable(
        internal_static_TypedValue_descriptor,
        new java.lang.String[] { "Type", "BoolValue", "StringValue", "NumberValue", "BytesValue", "DoubleValue", "Null", "ArrayValue", "ComponentType", "ImplicitlyNull", });
    internal_static_MetaDataOperationArgument_descriptor =
      getDescriptor().getMessageTypes().get(13);
    internal_static_MetaDataOperationArgument_fieldAccessorTable = new
      com.google.protobuf.GeneratedMessageV3.FieldAccessorTable(
        internal_static_MetaDataOperationArgument_descriptor,
        new java.lang.String[] { "StringValue", "BoolValue", "IntValue", "StringArrayValues", "IntArrayValues", "Type", });
    internal_static_QueryState_descriptor =
      getDescriptor().getMessageTypes().get(14);
    internal_static_QueryState_fieldAccessorTable = new
      com.google.protobuf.GeneratedMessageV3.FieldAccessorTable(
        internal_static_QueryState_descriptor,
        new java.lang.String[] { "Type", "Sql", "Op", "Args", "HasArgs", "HasSql", "HasOp", });
  }

  // @@protoc_insertion_point(outer_class_scope)
}