// Generated by the protocol buffer compiler.  DO NOT EDIT!
// source: keyapis/device/v1/keyapis_device_model_v1.proto

#include "keyapis/device/v1/keyapis_device_model_v1.pb.h"

#include <algorithm>
#include "google/protobuf/io/coded_stream.h"
#include "google/protobuf/extension_set.h"
#include "google/protobuf/wire_format_lite.h"
#include "google/protobuf/io/zero_copy_stream_impl_lite.h"
// @@protoc_insertion_point(includes)

// Must be included last.
#include "google/protobuf/port_def.inc"
PROTOBUF_PRAGMA_INIT_SEG
namespace _pb = ::PROTOBUF_NAMESPACE_ID;
namespace _pbi = ::PROTOBUF_NAMESPACE_ID::internal;
namespace keyapis {
namespace device {
namespace v1 {
template <typename>
PROTOBUF_CONSTEXPR Model::Model(
    ::_pbi::ConstantInitialized): _impl_{
    /*decltype(_impl_.id_)*/ 0

  , /*decltype(_impl_._cached_size_)*/{}} {}
struct ModelDefaultTypeInternal {
  PROTOBUF_CONSTEXPR ModelDefaultTypeInternal() : _instance(::_pbi::ConstantInitialized{}) {}
  ~ModelDefaultTypeInternal() {}
  union {
    Model _instance;
  };
};

PROTOBUF_ATTRIBUTE_NO_DESTROY PROTOBUF_CONSTINIT
    PROTOBUF_ATTRIBUTE_INIT_PRIORITY1 ModelDefaultTypeInternal _Model_default_instance_;
}  // namespace v1
}  // namespace device
}  // namespace keyapis
namespace keyapis {
namespace device {
namespace v1 {
bool Model_CapabilityType_IsValid(int value) {
  switch (value) {
    case 0:
    case 1:
    case 2:
    case 3:
    case 4:
    case 5:
    case 6:
    case 7:
    case 8:
    case 9:
    case 10:
    case 11:
    case 12:
    case 13:
    case 14:
    case 15:
    case 16:
    case 17:
    case 18:
    case 19:
    case 20:
    case 21:
      return true;
    default:
      return false;
  }
}
static ::PROTOBUF_NAMESPACE_ID::internal::ExplicitlyConstructed<std::string>
    Model_CapabilityType_strings[22] = {};

static const char Model_CapabilityType_names[] = {
    "AUTOCOLLECT"
    "CAMERA"
    "CAPABILITY_TYPE_UNKNOWN"
    "CHANGE_PASSWORD"
    "CMS_PHONES"
    "CONCIERGE_CALL"
    "CONSTANT_KEY"
    "DTMF_CODE"
    "EMERGENCY_CALL"
    "EMERGENCY_DOOR"
    "FACE_RECOGNITION"
    "FLAT_AUTOCOLLECT"
    "GATE"
    "NTP"
    "OPEN_DOOR"
    "REINSTALL"
    "SIP_CALL"
    "SIP_VIDEO"
    "SL3"
    "SYSLOG"
    "TEMPORARY_KEY"
    "TICKER"
};

static const ::PROTOBUF_NAMESPACE_ID::internal::EnumEntry Model_CapabilityType_entries[] =
    {
        {{&Model_CapabilityType_names[0], 11}, 9},
        {{&Model_CapabilityType_names[11], 6}, 20},
        {{&Model_CapabilityType_names[17], 23}, 0},
        {{&Model_CapabilityType_names[40], 15}, 1},
        {{&Model_CapabilityType_names[55], 10}, 15},
        {{&Model_CapabilityType_names[65], 14}, 8},
        {{&Model_CapabilityType_names[79], 12}, 14},
        {{&Model_CapabilityType_names[91], 9}, 2},
        {{&Model_CapabilityType_names[100], 14}, 21},
        {{&Model_CapabilityType_names[114], 14}, 6},
        {{&Model_CapabilityType_names[128], 16}, 19},
        {{&Model_CapabilityType_names[144], 16}, 3},
        {{&Model_CapabilityType_names[160], 4}, 12},
        {{&Model_CapabilityType_names[164], 3}, 18},
        {{&Model_CapabilityType_names[167], 9}, 11},
        {{&Model_CapabilityType_names[176], 9}, 5},
        {{&Model_CapabilityType_names[185], 8}, 4},
        {{&Model_CapabilityType_names[193], 9}, 13},
        {{&Model_CapabilityType_names[202], 3}, 16},
        {{&Model_CapabilityType_names[205], 6}, 17},
        {{&Model_CapabilityType_names[211], 13}, 10},
        {{&Model_CapabilityType_names[224], 6}, 7},
};

static const int Model_CapabilityType_entries_by_number[] = {
    2,  // 0 -> CAPABILITY_TYPE_UNKNOWN
    3,  // 1 -> CHANGE_PASSWORD
    7,  // 2 -> DTMF_CODE
    11,  // 3 -> FLAT_AUTOCOLLECT
    16,  // 4 -> SIP_CALL
    15,  // 5 -> REINSTALL
    9,  // 6 -> EMERGENCY_DOOR
    21,  // 7 -> TICKER
    5,  // 8 -> CONCIERGE_CALL
    0,  // 9 -> AUTOCOLLECT
    20,  // 10 -> TEMPORARY_KEY
    14,  // 11 -> OPEN_DOOR
    12,  // 12 -> GATE
    17,  // 13 -> SIP_VIDEO
    6,  // 14 -> CONSTANT_KEY
    4,  // 15 -> CMS_PHONES
    18,  // 16 -> SL3
    19,  // 17 -> SYSLOG
    13,  // 18 -> NTP
    10,  // 19 -> FACE_RECOGNITION
    1,  // 20 -> CAMERA
    8,  // 21 -> EMERGENCY_CALL
};

const std::string& Model_CapabilityType_Name(Model_CapabilityType value) {
  static const bool kDummy =
      ::PROTOBUF_NAMESPACE_ID::internal::InitializeEnumStrings(
          Model_CapabilityType_entries, Model_CapabilityType_entries_by_number,
          22, Model_CapabilityType_strings);
  (void)kDummy;

  int idx = ::PROTOBUF_NAMESPACE_ID::internal::LookUpEnumName(
      Model_CapabilityType_entries, Model_CapabilityType_entries_by_number, 22,
      value);
  return idx == -1 ? ::PROTOBUF_NAMESPACE_ID::internal::GetEmptyString()
                   : Model_CapabilityType_strings[idx].get();
}

bool Model_CapabilityType_Parse(absl::string_view name, Model_CapabilityType* value) {
  int int_value;
  bool success = ::PROTOBUF_NAMESPACE_ID::internal::LookUpEnumValue(
      Model_CapabilityType_entries, 22, name, &int_value);
  if (success) {
    *value = static_cast<Model_CapabilityType>(int_value);
  }
  return success;
}
#if (__cplusplus < 201703) && \
  (!defined(_MSC_VER) || (_MSC_VER >= 1900 && _MSC_VER < 1912))

constexpr Model_CapabilityType Model::CAPABILITY_TYPE_UNKNOWN;
constexpr Model_CapabilityType Model::CHANGE_PASSWORD;
constexpr Model_CapabilityType Model::DTMF_CODE;
constexpr Model_CapabilityType Model::FLAT_AUTOCOLLECT;
constexpr Model_CapabilityType Model::SIP_CALL;
constexpr Model_CapabilityType Model::REINSTALL;
constexpr Model_CapabilityType Model::EMERGENCY_DOOR;
constexpr Model_CapabilityType Model::TICKER;
constexpr Model_CapabilityType Model::CONCIERGE_CALL;
constexpr Model_CapabilityType Model::AUTOCOLLECT;
constexpr Model_CapabilityType Model::TEMPORARY_KEY;
constexpr Model_CapabilityType Model::OPEN_DOOR;
constexpr Model_CapabilityType Model::GATE;
constexpr Model_CapabilityType Model::SIP_VIDEO;
constexpr Model_CapabilityType Model::CONSTANT_KEY;
constexpr Model_CapabilityType Model::CMS_PHONES;
constexpr Model_CapabilityType Model::SL3;
constexpr Model_CapabilityType Model::SYSLOG;
constexpr Model_CapabilityType Model::NTP;
constexpr Model_CapabilityType Model::FACE_RECOGNITION;
constexpr Model_CapabilityType Model::CAMERA;
constexpr Model_CapabilityType Model::EMERGENCY_CALL;
constexpr Model_CapabilityType Model::CapabilityType_MIN;
constexpr Model_CapabilityType Model::CapabilityType_MAX;
constexpr int Model::CapabilityType_ARRAYSIZE;

#endif  // (__cplusplus < 201703) &&
        // (!defined(_MSC_VER) || (_MSC_VER >= 1900 && _MSC_VER < 1912))
// ===================================================================

class Model::_Internal {
 public:
};

Model::Model(::PROTOBUF_NAMESPACE_ID::Arena* arena)
  : ::PROTOBUF_NAMESPACE_ID::MessageLite(arena) {
  SharedCtor(arena);
  // @@protoc_insertion_point(arena_constructor:keyapis.device.v1.Model)
}
Model::Model(const Model& from)
  : ::PROTOBUF_NAMESPACE_ID::MessageLite(), _impl_(from._impl_) {
  _internal_metadata_.MergeFrom<std::string>(
      from._internal_metadata_);
  // @@protoc_insertion_point(copy_constructor:keyapis.device.v1.Model)
}

inline void Model::SharedCtor(::_pb::Arena* arena) {
  (void)arena;
  new (&_impl_) Impl_{
      decltype(_impl_.id_) { 0 }

    , /*decltype(_impl_._cached_size_)*/{}
  };
}

Model::~Model() {
  // @@protoc_insertion_point(destructor:keyapis.device.v1.Model)
  if (auto *arena = _internal_metadata_.DeleteReturnArena<std::string>()) {
  (void)arena;
    return;
  }
  SharedDtor();
}

inline void Model::SharedDtor() {
  ABSL_DCHECK(GetArenaForAllocation() == nullptr);
}

void Model::SetCachedSize(int size) const {
  _impl_._cached_size_.Set(size);
}

void Model::Clear() {
// @@protoc_insertion_point(message_clear_start:keyapis.device.v1.Model)
  ::uint32_t cached_has_bits = 0;
  // Prevent compiler warnings about cached_has_bits being unused
  (void) cached_has_bits;

  _impl_.id_ = 0;
  _internal_metadata_.Clear<std::string>();
}

const char* Model::_InternalParse(const char* ptr, ::_pbi::ParseContext* ctx) {
#define CHK_(x) if (PROTOBUF_PREDICT_FALSE(!(x))) goto failure
  while (!ctx->Done(&ptr)) {
    ::uint32_t tag;
    ptr = ::_pbi::ReadTag(ptr, &tag);
    switch (tag >> 3) {
      // int32 id = 1;
      case 1:
        if (PROTOBUF_PREDICT_TRUE(static_cast<::uint8_t>(tag) == 8)) {
          _impl_.id_ = ::PROTOBUF_NAMESPACE_ID::internal::ReadVarint32(&ptr);
          CHK_(ptr);
        } else {
          goto handle_unusual;
        }
        continue;
      default:
        goto handle_unusual;
    }  // switch
  handle_unusual:
    if ((tag == 0) || ((tag & 7) == 4)) {
      CHK_(ptr);
      ctx->SetLastTag(tag);
      goto message_done;
    }
    ptr = UnknownFieldParse(
        tag,
        _internal_metadata_.mutable_unknown_fields<std::string>(),
        ptr, ctx);
    CHK_(ptr != nullptr);
  }  // while
message_done:
  return ptr;
failure:
  ptr = nullptr;
  goto message_done;
#undef CHK_
}

::uint8_t* Model::_InternalSerialize(
    ::uint8_t* target, ::PROTOBUF_NAMESPACE_ID::io::EpsCopyOutputStream* stream) const {
  // @@protoc_insertion_point(serialize_to_array_start:keyapis.device.v1.Model)
  ::uint32_t cached_has_bits = 0;
  (void) cached_has_bits;

  // int32 id = 1;
  if (this->_internal_id() != 0) {
    target = stream->EnsureSpace(target);
    target = ::_pbi::WireFormatLite::WriteInt32ToArray(
        1, this->_internal_id(), target);
  }

  if (PROTOBUF_PREDICT_FALSE(_internal_metadata_.have_unknown_fields())) {
    target = stream->WriteRaw(_internal_metadata_.unknown_fields<std::string>(::PROTOBUF_NAMESPACE_ID::internal::GetEmptyString).data(),
        static_cast<int>(_internal_metadata_.unknown_fields<std::string>(::PROTOBUF_NAMESPACE_ID::internal::GetEmptyString).size()), target);
  }
  // @@protoc_insertion_point(serialize_to_array_end:keyapis.device.v1.Model)
  return target;
}

::size_t Model::ByteSizeLong() const {
// @@protoc_insertion_point(message_byte_size_start:keyapis.device.v1.Model)
  ::size_t total_size = 0;

  ::uint32_t cached_has_bits = 0;
  // Prevent compiler warnings about cached_has_bits being unused
  (void) cached_has_bits;

  // int32 id = 1;
  if (this->_internal_id() != 0) {
    total_size += ::_pbi::WireFormatLite::Int32SizePlusOne(
        this->_internal_id());
  }

  if (PROTOBUF_PREDICT_FALSE(_internal_metadata_.have_unknown_fields())) {
    total_size += _internal_metadata_.unknown_fields<std::string>(::PROTOBUF_NAMESPACE_ID::internal::GetEmptyString).size();
  }
  int cached_size = ::_pbi::ToCachedSize(total_size);
  SetCachedSize(cached_size);
  return total_size;
}

void Model::CheckTypeAndMergeFrom(
    const ::PROTOBUF_NAMESPACE_ID::MessageLite& from) {
  MergeFrom(*::_pbi::DownCast<const Model*>(
      &from));
}

void Model::MergeFrom(const Model& from) {
  Model* const _this = this;
  // @@protoc_insertion_point(class_specific_merge_from_start:keyapis.device.v1.Model)
  ABSL_DCHECK_NE(&from, _this);
  ::uint32_t cached_has_bits = 0;
  (void) cached_has_bits;

  if (from._internal_id() != 0) {
    _this->_internal_set_id(from._internal_id());
  }
  _this->_internal_metadata_.MergeFrom<std::string>(from._internal_metadata_);
}

void Model::CopyFrom(const Model& from) {
// @@protoc_insertion_point(class_specific_copy_from_start:keyapis.device.v1.Model)
  if (&from == this) return;
  Clear();
  MergeFrom(from);
}

bool Model::IsInitialized() const {
  return true;
}

void Model::InternalSwap(Model* other) {
  using std::swap;
  _internal_metadata_.InternalSwap(&other->_internal_metadata_);

  swap(_impl_.id_, other->_impl_.id_);
}

std::string Model::GetTypeName() const {
  return "keyapis.device.v1.Model";
}

// @@protoc_insertion_point(namespace_scope)
}  // namespace v1
}  // namespace device
}  // namespace keyapis
PROTOBUF_NAMESPACE_OPEN
template<> PROTOBUF_NOINLINE ::keyapis::device::v1::Model*
Arena::CreateMaybeMessage< ::keyapis::device::v1::Model >(Arena* arena) {
  return Arena::CreateMessageInternal< ::keyapis::device::v1::Model >(arena);
}
PROTOBUF_NAMESPACE_CLOSE
// @@protoc_insertion_point(global_scope)
#include "google/protobuf/port_undef.inc"
