// Generated by the protocol buffer compiler.  DO NOT EDIT!
// NO CHECKED-IN PROTOBUF GENCODE
// source: xla/tsl/protobuf/rpc_options.proto
// Protobuf C++ Version: 5.28.3

#ifndef GOOGLE_PROTOBUF_INCLUDED_xla_2ftsl_2fprotobuf_2frpc_5foptions_2eproto_2epb_2eh
#define GOOGLE_PROTOBUF_INCLUDED_xla_2ftsl_2fprotobuf_2frpc_5foptions_2eproto_2epb_2eh

#include <limits>
#include <string>
#include <type_traits>
#include <utility>

#include "google/protobuf/runtime_version.h"
#if PROTOBUF_VERSION != 5028003
#error "Protobuf C++ gencode is built with an incompatible version of"
#error "Protobuf C++ headers/runtime. See"
#error "https://protobuf.dev/support/cross-version-runtime-guarantee/#cpp"
#endif
#include "google/protobuf/io/coded_stream.h"
#include "google/protobuf/arena.h"
#include "google/protobuf/arenastring.h"
#include "google/protobuf/generated_message_tctable_decl.h"
#include "google/protobuf/generated_message_util.h"
#include "google/protobuf/metadata_lite.h"
#include "google/protobuf/generated_message_reflection.h"
#include "google/protobuf/message.h"
#include "google/protobuf/repeated_field.h"  // IWYU pragma: export
#include "google/protobuf/extension_set.h"  // IWYU pragma: export
#include "google/protobuf/unknown_field_set.h"
// @@protoc_insertion_point(includes)

// Must be included last.
#include "google/protobuf/port_def.inc"

#define PROTOBUF_INTERNAL_EXPORT_xla_2ftsl_2fprotobuf_2frpc_5foptions_2eproto PROTOBUF_EXPORT

namespace google {
namespace protobuf {
namespace internal {
class AnyMetadata;
}  // namespace internal
}  // namespace protobuf
}  // namespace google

// Internal implementation detail -- do not use these members.
struct PROTOBUF_EXPORT TableStruct_xla_2ftsl_2fprotobuf_2frpc_5foptions_2eproto {
  static const ::uint32_t offsets[];
};
PROTOBUF_EXPORT extern const ::google::protobuf::internal::DescriptorTable
    descriptor_table_xla_2ftsl_2fprotobuf_2frpc_5foptions_2eproto;
namespace tensorflow {
class RPCOptions;
struct RPCOptionsDefaultTypeInternal;
PROTOBUF_EXPORT extern RPCOptionsDefaultTypeInternal _RPCOptions_default_instance_;
}  // namespace tensorflow
namespace google {
namespace protobuf {
}  // namespace protobuf
}  // namespace google

namespace tensorflow {

// ===================================================================


// -------------------------------------------------------------------

class PROTOBUF_EXPORT RPCOptions final : public ::google::protobuf::Message
/* @@protoc_insertion_point(class_definition:tensorflow.RPCOptions) */ {
 public:
  inline RPCOptions() : RPCOptions(nullptr) {}
  ~RPCOptions() PROTOBUF_FINAL;
  template <typename = void>
  explicit PROTOBUF_CONSTEXPR RPCOptions(
      ::google::protobuf::internal::ConstantInitialized);

  inline RPCOptions(const RPCOptions& from) : RPCOptions(nullptr, from) {}
  inline RPCOptions(RPCOptions&& from) noexcept
      : RPCOptions(nullptr, std::move(from)) {}
  inline RPCOptions& operator=(const RPCOptions& from) {
    CopyFrom(from);
    return *this;
  }
  inline RPCOptions& operator=(RPCOptions&& from) noexcept {
    if (this == &from) return *this;
    if (GetArena() == from.GetArena()
#ifdef PROTOBUF_FORCE_COPY_IN_MOVE
        && GetArena() != nullptr
#endif  // !PROTOBUF_FORCE_COPY_IN_MOVE
    ) {
      InternalSwap(&from);
    } else {
      CopyFrom(from);
    }
    return *this;
  }

  inline const ::google::protobuf::UnknownFieldSet& unknown_fields() const
      ABSL_ATTRIBUTE_LIFETIME_BOUND {
    return _internal_metadata_.unknown_fields<::google::protobuf::UnknownFieldSet>(::google::protobuf::UnknownFieldSet::default_instance);
  }
  inline ::google::protobuf::UnknownFieldSet* mutable_unknown_fields()
      ABSL_ATTRIBUTE_LIFETIME_BOUND {
    return _internal_metadata_.mutable_unknown_fields<::google::protobuf::UnknownFieldSet>();
  }

  static const ::google::protobuf::Descriptor* descriptor() {
    return GetDescriptor();
  }
  static const ::google::protobuf::Descriptor* GetDescriptor() {
    return default_instance().GetMetadata().descriptor;
  }
  static const ::google::protobuf::Reflection* GetReflection() {
    return default_instance().GetMetadata().reflection;
  }
  static const RPCOptions& default_instance() {
    return *internal_default_instance();
  }
  static inline const RPCOptions* internal_default_instance() {
    return reinterpret_cast<const RPCOptions*>(
        &_RPCOptions_default_instance_);
  }
  static constexpr int kIndexInFileMessages = 0;
  friend void swap(RPCOptions& a, RPCOptions& b) { a.Swap(&b); }
  inline void Swap(RPCOptions* other) {
    if (other == this) return;
#ifdef PROTOBUF_FORCE_COPY_IN_SWAP
    if (GetArena() != nullptr && GetArena() == other->GetArena()) {
#else   // PROTOBUF_FORCE_COPY_IN_SWAP
    if (GetArena() == other->GetArena()) {
#endif  // !PROTOBUF_FORCE_COPY_IN_SWAP
      InternalSwap(other);
    } else {
      ::google::protobuf::internal::GenericSwap(this, other);
    }
  }
  void UnsafeArenaSwap(RPCOptions* other) {
    if (other == this) return;
    ABSL_DCHECK(GetArena() == other->GetArena());
    InternalSwap(other);
  }

  // implements Message ----------------------------------------------

  RPCOptions* New(::google::protobuf::Arena* arena = nullptr) const PROTOBUF_FINAL {
    return ::google::protobuf::Message::DefaultConstruct<RPCOptions>(arena);
  }
  using ::google::protobuf::Message::CopyFrom;
  void CopyFrom(const RPCOptions& from);
  using ::google::protobuf::Message::MergeFrom;
  void MergeFrom(const RPCOptions& from) { RPCOptions::MergeImpl(*this, from); }

  private:
  static void MergeImpl(
      ::google::protobuf::MessageLite& to_msg,
      const ::google::protobuf::MessageLite& from_msg);

  public:
  bool IsInitialized() const {
    return true;
  }
  ABSL_ATTRIBUTE_REINITIALIZES void Clear() PROTOBUF_FINAL;
  #if defined(PROTOBUF_CUSTOM_VTABLE)
  private:
  static ::size_t ByteSizeLong(const ::google::protobuf::MessageLite& msg);
  static ::uint8_t* _InternalSerialize(
      const MessageLite& msg, ::uint8_t* target,
      ::google::protobuf::io::EpsCopyOutputStream* stream);

  public:
  ::size_t ByteSizeLong() const { return ByteSizeLong(*this); }
  ::uint8_t* _InternalSerialize(
      ::uint8_t* target,
      ::google::protobuf::io::EpsCopyOutputStream* stream) const {
    return _InternalSerialize(*this, target, stream);
  }
  #else   // PROTOBUF_CUSTOM_VTABLE
  ::size_t ByteSizeLong() const final;
  ::uint8_t* _InternalSerialize(
      ::uint8_t* target,
      ::google::protobuf::io::EpsCopyOutputStream* stream) const final;
  #endif  // PROTOBUF_CUSTOM_VTABLE
  int GetCachedSize() const { return _impl_._cached_size_.Get(); }

  private:
  void SharedCtor(::google::protobuf::Arena* arena);
  void SharedDtor();
  void InternalSwap(RPCOptions* other);
 private:
  friend class ::google::protobuf::internal::AnyMetadata;
  static ::absl::string_view FullMessageName() { return "tensorflow.RPCOptions"; }

 protected:
  explicit RPCOptions(::google::protobuf::Arena* arena);
  RPCOptions(::google::protobuf::Arena* arena, const RPCOptions& from);
  RPCOptions(::google::protobuf::Arena* arena, RPCOptions&& from) noexcept
      : RPCOptions(arena) {
    *this = ::std::move(from);
  }
  const ::google::protobuf::Message::ClassData* GetClassData() const PROTOBUF_FINAL;
  static const ::google::protobuf::Message::ClassDataFull _class_data_;

 public:
  ::google::protobuf::Metadata GetMetadata() const;
  // nested types ----------------------------------------------------

  // accessors -------------------------------------------------------
  enum : int {
    kCompressionAlgorithmFieldNumber = 2,
    kCompressionLevelFieldNumber = 3,
    kUseRpcForInprocessMasterFieldNumber = 1,
    kCacheRpcResponseFieldNumber = 4,
    kDisableSessionConnectionSharingFieldNumber = 5,
    kNumChannelsPerTargetFieldNumber = 6,
  };
  // string compression_algorithm = 2;
  void clear_compression_algorithm() ;
  const std::string& compression_algorithm() const;
  template <typename Arg_ = const std::string&, typename... Args_>
  void set_compression_algorithm(Arg_&& arg, Args_... args);
  std::string* mutable_compression_algorithm();
  PROTOBUF_NODISCARD std::string* release_compression_algorithm();
  void set_allocated_compression_algorithm(std::string* value);

  private:
  const std::string& _internal_compression_algorithm() const;
  inline PROTOBUF_ALWAYS_INLINE void _internal_set_compression_algorithm(
      const std::string& value);
  std::string* _internal_mutable_compression_algorithm();

  public:
  // int32 compression_level = 3;
  void clear_compression_level() ;
  ::int32_t compression_level() const;
  void set_compression_level(::int32_t value);

  private:
  ::int32_t _internal_compression_level() const;
  void _internal_set_compression_level(::int32_t value);

  public:
  // bool use_rpc_for_inprocess_master = 1;
  void clear_use_rpc_for_inprocess_master() ;
  bool use_rpc_for_inprocess_master() const;
  void set_use_rpc_for_inprocess_master(bool value);

  private:
  bool _internal_use_rpc_for_inprocess_master() const;
  void _internal_set_use_rpc_for_inprocess_master(bool value);

  public:
  // bool cache_rpc_response = 4;
  void clear_cache_rpc_response() ;
  bool cache_rpc_response() const;
  void set_cache_rpc_response(bool value);

  private:
  bool _internal_cache_rpc_response() const;
  void _internal_set_cache_rpc_response(bool value);

  public:
  // bool disable_session_connection_sharing = 5;
  void clear_disable_session_connection_sharing() ;
  bool disable_session_connection_sharing() const;
  void set_disable_session_connection_sharing(bool value);

  private:
  bool _internal_disable_session_connection_sharing() const;
  void _internal_set_disable_session_connection_sharing(bool value);

  public:
  // int32 num_channels_per_target = 6;
  void clear_num_channels_per_target() ;
  ::int32_t num_channels_per_target() const;
  void set_num_channels_per_target(::int32_t value);

  private:
  ::int32_t _internal_num_channels_per_target() const;
  void _internal_set_num_channels_per_target(::int32_t value);

  public:
  // @@protoc_insertion_point(class_scope:tensorflow.RPCOptions)
 private:
  class _Internal;
  friend class ::google::protobuf::internal::TcParser;
  static const ::google::protobuf::internal::TcParseTable<
      3, 6, 0,
      51, 2>
      _table_;


  friend class ::google::protobuf::MessageLite;
  friend class ::google::protobuf::Arena;
  template <typename T>
  friend class ::google::protobuf::Arena::InternalHelper;
  using InternalArenaConstructable_ = void;
  using DestructorSkippable_ = void;
  struct Impl_ {
    inline explicit constexpr Impl_(
        ::google::protobuf::internal::ConstantInitialized) noexcept;
    inline explicit Impl_(::google::protobuf::internal::InternalVisibility visibility,
                          ::google::protobuf::Arena* arena);
    inline explicit Impl_(::google::protobuf::internal::InternalVisibility visibility,
                          ::google::protobuf::Arena* arena, const Impl_& from,
                          const RPCOptions& from_msg);
    ::google::protobuf::internal::ArenaStringPtr compression_algorithm_;
    ::int32_t compression_level_;
    bool use_rpc_for_inprocess_master_;
    bool cache_rpc_response_;
    bool disable_session_connection_sharing_;
    ::int32_t num_channels_per_target_;
    mutable ::google::protobuf::internal::CachedSize _cached_size_;
    PROTOBUF_TSAN_DECLARE_MEMBER
  };
  union { Impl_ _impl_; };
  friend struct ::TableStruct_xla_2ftsl_2fprotobuf_2frpc_5foptions_2eproto;
};

// ===================================================================




// ===================================================================


#ifdef __GNUC__
#pragma GCC diagnostic push
#pragma GCC diagnostic ignored "-Wstrict-aliasing"
#endif  // __GNUC__
// -------------------------------------------------------------------

// RPCOptions

// bool use_rpc_for_inprocess_master = 1;
inline void RPCOptions::clear_use_rpc_for_inprocess_master() {
  ::google::protobuf::internal::TSanWrite(&_impl_);
  _impl_.use_rpc_for_inprocess_master_ = false;
}
inline bool RPCOptions::use_rpc_for_inprocess_master() const {
  // @@protoc_insertion_point(field_get:tensorflow.RPCOptions.use_rpc_for_inprocess_master)
  return _internal_use_rpc_for_inprocess_master();
}
inline void RPCOptions::set_use_rpc_for_inprocess_master(bool value) {
  _internal_set_use_rpc_for_inprocess_master(value);
  // @@protoc_insertion_point(field_set:tensorflow.RPCOptions.use_rpc_for_inprocess_master)
}
inline bool RPCOptions::_internal_use_rpc_for_inprocess_master() const {
  ::google::protobuf::internal::TSanRead(&_impl_);
  return _impl_.use_rpc_for_inprocess_master_;
}
inline void RPCOptions::_internal_set_use_rpc_for_inprocess_master(bool value) {
  ::google::protobuf::internal::TSanWrite(&_impl_);
  _impl_.use_rpc_for_inprocess_master_ = value;
}

// string compression_algorithm = 2;
inline void RPCOptions::clear_compression_algorithm() {
  ::google::protobuf::internal::TSanWrite(&_impl_);
  _impl_.compression_algorithm_.ClearToEmpty();
}
inline const std::string& RPCOptions::compression_algorithm() const
    ABSL_ATTRIBUTE_LIFETIME_BOUND {
  // @@protoc_insertion_point(field_get:tensorflow.RPCOptions.compression_algorithm)
  return _internal_compression_algorithm();
}
template <typename Arg_, typename... Args_>
inline PROTOBUF_ALWAYS_INLINE void RPCOptions::set_compression_algorithm(Arg_&& arg,
                                                     Args_... args) {
  ::google::protobuf::internal::TSanWrite(&_impl_);
  _impl_.compression_algorithm_.Set(static_cast<Arg_&&>(arg), args..., GetArena());
  // @@protoc_insertion_point(field_set:tensorflow.RPCOptions.compression_algorithm)
}
inline std::string* RPCOptions::mutable_compression_algorithm() ABSL_ATTRIBUTE_LIFETIME_BOUND {
  std::string* _s = _internal_mutable_compression_algorithm();
  // @@protoc_insertion_point(field_mutable:tensorflow.RPCOptions.compression_algorithm)
  return _s;
}
inline const std::string& RPCOptions::_internal_compression_algorithm() const {
  ::google::protobuf::internal::TSanRead(&_impl_);
  return _impl_.compression_algorithm_.Get();
}
inline void RPCOptions::_internal_set_compression_algorithm(const std::string& value) {
  ::google::protobuf::internal::TSanWrite(&_impl_);
  _impl_.compression_algorithm_.Set(value, GetArena());
}
inline std::string* RPCOptions::_internal_mutable_compression_algorithm() {
  ::google::protobuf::internal::TSanWrite(&_impl_);
  return _impl_.compression_algorithm_.Mutable( GetArena());
}
inline std::string* RPCOptions::release_compression_algorithm() {
  ::google::protobuf::internal::TSanWrite(&_impl_);
  // @@protoc_insertion_point(field_release:tensorflow.RPCOptions.compression_algorithm)
  return _impl_.compression_algorithm_.Release();
}
inline void RPCOptions::set_allocated_compression_algorithm(std::string* value) {
  ::google::protobuf::internal::TSanWrite(&_impl_);
  _impl_.compression_algorithm_.SetAllocated(value, GetArena());
  #ifdef PROTOBUF_FORCE_COPY_DEFAULT_STRING
        if (_impl_.compression_algorithm_.IsDefault()) {
          _impl_.compression_algorithm_.Set("", GetArena());
        }
  #endif  // PROTOBUF_FORCE_COPY_DEFAULT_STRING
  // @@protoc_insertion_point(field_set_allocated:tensorflow.RPCOptions.compression_algorithm)
}

// int32 compression_level = 3;
inline void RPCOptions::clear_compression_level() {
  ::google::protobuf::internal::TSanWrite(&_impl_);
  _impl_.compression_level_ = 0;
}
inline ::int32_t RPCOptions::compression_level() const {
  // @@protoc_insertion_point(field_get:tensorflow.RPCOptions.compression_level)
  return _internal_compression_level();
}
inline void RPCOptions::set_compression_level(::int32_t value) {
  _internal_set_compression_level(value);
  // @@protoc_insertion_point(field_set:tensorflow.RPCOptions.compression_level)
}
inline ::int32_t RPCOptions::_internal_compression_level() const {
  ::google::protobuf::internal::TSanRead(&_impl_);
  return _impl_.compression_level_;
}
inline void RPCOptions::_internal_set_compression_level(::int32_t value) {
  ::google::protobuf::internal::TSanWrite(&_impl_);
  _impl_.compression_level_ = value;
}

// bool cache_rpc_response = 4;
inline void RPCOptions::clear_cache_rpc_response() {
  ::google::protobuf::internal::TSanWrite(&_impl_);
  _impl_.cache_rpc_response_ = false;
}
inline bool RPCOptions::cache_rpc_response() const {
  // @@protoc_insertion_point(field_get:tensorflow.RPCOptions.cache_rpc_response)
  return _internal_cache_rpc_response();
}
inline void RPCOptions::set_cache_rpc_response(bool value) {
  _internal_set_cache_rpc_response(value);
  // @@protoc_insertion_point(field_set:tensorflow.RPCOptions.cache_rpc_response)
}
inline bool RPCOptions::_internal_cache_rpc_response() const {
  ::google::protobuf::internal::TSanRead(&_impl_);
  return _impl_.cache_rpc_response_;
}
inline void RPCOptions::_internal_set_cache_rpc_response(bool value) {
  ::google::protobuf::internal::TSanWrite(&_impl_);
  _impl_.cache_rpc_response_ = value;
}

// bool disable_session_connection_sharing = 5;
inline void RPCOptions::clear_disable_session_connection_sharing() {
  ::google::protobuf::internal::TSanWrite(&_impl_);
  _impl_.disable_session_connection_sharing_ = false;
}
inline bool RPCOptions::disable_session_connection_sharing() const {
  // @@protoc_insertion_point(field_get:tensorflow.RPCOptions.disable_session_connection_sharing)
  return _internal_disable_session_connection_sharing();
}
inline void RPCOptions::set_disable_session_connection_sharing(bool value) {
  _internal_set_disable_session_connection_sharing(value);
  // @@protoc_insertion_point(field_set:tensorflow.RPCOptions.disable_session_connection_sharing)
}
inline bool RPCOptions::_internal_disable_session_connection_sharing() const {
  ::google::protobuf::internal::TSanRead(&_impl_);
  return _impl_.disable_session_connection_sharing_;
}
inline void RPCOptions::_internal_set_disable_session_connection_sharing(bool value) {
  ::google::protobuf::internal::TSanWrite(&_impl_);
  _impl_.disable_session_connection_sharing_ = value;
}

// int32 num_channels_per_target = 6;
inline void RPCOptions::clear_num_channels_per_target() {
  ::google::protobuf::internal::TSanWrite(&_impl_);
  _impl_.num_channels_per_target_ = 0;
}
inline ::int32_t RPCOptions::num_channels_per_target() const {
  // @@protoc_insertion_point(field_get:tensorflow.RPCOptions.num_channels_per_target)
  return _internal_num_channels_per_target();
}
inline void RPCOptions::set_num_channels_per_target(::int32_t value) {
  _internal_set_num_channels_per_target(value);
  // @@protoc_insertion_point(field_set:tensorflow.RPCOptions.num_channels_per_target)
}
inline ::int32_t RPCOptions::_internal_num_channels_per_target() const {
  ::google::protobuf::internal::TSanRead(&_impl_);
  return _impl_.num_channels_per_target_;
}
inline void RPCOptions::_internal_set_num_channels_per_target(::int32_t value) {
  ::google::protobuf::internal::TSanWrite(&_impl_);
  _impl_.num_channels_per_target_ = value;
}

#ifdef __GNUC__
#pragma GCC diagnostic pop
#endif  // __GNUC__

// @@protoc_insertion_point(namespace_scope)
}  // namespace tensorflow


// @@protoc_insertion_point(global_scope)

#include "google/protobuf/port_undef.inc"

#endif  // GOOGLE_PROTOBUF_INCLUDED_xla_2ftsl_2fprotobuf_2frpc_5foptions_2eproto_2epb_2eh
