diff --git a/c-deps/libroach/protos/roachpb/api.pb.cc b/c-deps/libroach/protos/roachpb/api.pb.cc index b831ce112132..747a83072ac0 100644 --- a/c-deps/libroach/protos/roachpb/api.pb.cc +++ b/c-deps/libroach/protos/roachpb/api.pb.cc @@ -28,7 +28,6 @@ extern PROTOBUF_INTERNAL_EXPORT_protobuf_roachpb_2fapi_2eproto ::google::protobu extern PROTOBUF_INTERNAL_EXPORT_protobuf_roachpb_2fapi_2eproto ::google::protobuf::internal::SCCInfo<0> scc_info_ImportRequest_TableRekey; extern PROTOBUF_INTERNAL_EXPORT_protobuf_roachpb_2fapi_2eproto ::google::protobuf::internal::SCCInfo<0> scc_info_RequestHeader; extern PROTOBUF_INTERNAL_EXPORT_protobuf_roachpb_2fapi_2eproto ::google::protobuf::internal::SCCInfo<0> scc_info_ScanOptions; -extern PROTOBUF_INTERNAL_EXPORT_protobuf_roachpb_2fapi_2eproto ::google::protobuf::internal::SCCInfo<1> scc_info_AddSSTableRequest; extern PROTOBUF_INTERNAL_EXPORT_protobuf_roachpb_2fapi_2eproto ::google::protobuf::internal::SCCInfo<1> scc_info_AddSSTableResponse; extern PROTOBUF_INTERNAL_EXPORT_protobuf_roachpb_2fapi_2eproto ::google::protobuf::internal::SCCInfo<1> scc_info_AdminMergeRequest; extern PROTOBUF_INTERNAL_EXPORT_protobuf_roachpb_2fapi_2eproto ::google::protobuf::internal::SCCInfo<1> scc_info_AdminMergeResponse; @@ -81,6 +80,7 @@ extern PROTOBUF_INTERNAL_EXPORT_protobuf_roachpb_2fapi_2eproto ::google::protobu extern PROTOBUF_INTERNAL_EXPORT_protobuf_roachpb_2fapi_2eproto ::google::protobuf::internal::SCCInfo<1> scc_info_TruncateLogRequest; extern PROTOBUF_INTERNAL_EXPORT_protobuf_roachpb_2fapi_2eproto ::google::protobuf::internal::SCCInfo<1> scc_info_TruncateLogResponse; extern PROTOBUF_INTERNAL_EXPORT_protobuf_roachpb_2fapi_2eproto ::google::protobuf::internal::SCCInfo<1> scc_info_WriteBatchResponse; +extern PROTOBUF_INTERNAL_EXPORT_protobuf_roachpb_2fapi_2eproto ::google::protobuf::internal::SCCInfo<2> scc_info_AddSSTableRequest; extern PROTOBUF_INTERNAL_EXPORT_protobuf_roachpb_2fapi_2eproto ::google::protobuf::internal::SCCInfo<2> scc_info_AdminChangeReplicasResponse; extern PROTOBUF_INTERNAL_EXPORT_protobuf_roachpb_2fapi_2eproto ::google::protobuf::internal::SCCInfo<2> scc_info_AdminRelocateRangeRequest; extern PROTOBUF_INTERNAL_EXPORT_protobuf_roachpb_2fapi_2eproto ::google::protobuf::internal::SCCInfo<2> scc_info_AdminScatterResponse; @@ -2316,9 +2316,10 @@ static void InitDefaultsAddSSTableRequest() { ::cockroach::roachpb::AddSSTableRequest::InitAsDefaultInstance(); } -::google::protobuf::internal::SCCInfo<1> scc_info_AddSSTableRequest = - {{ATOMIC_VAR_INIT(::google::protobuf::internal::SCCInfoBase::kUninitialized), 1, InitDefaultsAddSSTableRequest}, { - &protobuf_roachpb_2fapi_2eproto::scc_info_RequestHeader.base,}}; +::google::protobuf::internal::SCCInfo<2> scc_info_AddSSTableRequest = + {{ATOMIC_VAR_INIT(::google::protobuf::internal::SCCInfoBase::kUninitialized), 2, InitDefaultsAddSSTableRequest}, { + &protobuf_roachpb_2fapi_2eproto::scc_info_RequestHeader.base, + &protobuf_storage_2fengine_2fenginepb_2fmvcc_2eproto::scc_info_MVCCStats.base,}}; static void InitDefaultsAddSSTableResponse() { GOOGLE_PROTOBUF_VERIFY_VERSION; @@ -26914,11 +26915,20 @@ ::std::string AdminScatterResponse::GetTypeName() const { void AddSSTableRequest::InitAsDefaultInstance() { ::cockroach::roachpb::_AddSSTableRequest_default_instance_._instance.get_mutable()->header_ = const_cast< ::cockroach::roachpb::RequestHeader*>( ::cockroach::roachpb::RequestHeader::internal_default_instance()); + ::cockroach::roachpb::_AddSSTableRequest_default_instance_._instance.get_mutable()->mvcc_stats_ = const_cast< ::cockroach::storage::engine::enginepb::MVCCStats*>( + ::cockroach::storage::engine::enginepb::MVCCStats::internal_default_instance()); +} +void AddSSTableRequest::clear_mvcc_stats() { + if (GetArenaNoVirtual() == NULL && mvcc_stats_ != NULL) { + delete mvcc_stats_; + } + mvcc_stats_ = NULL; } #if !defined(_MSC_VER) || _MSC_VER >= 1900 const int AddSSTableRequest::kHeaderFieldNumber; const int AddSSTableRequest::kDataFieldNumber; const int AddSSTableRequest::kDisallowShadowingFieldNumber; +const int AddSSTableRequest::kMvccStatsFieldNumber; #endif // !defined(_MSC_VER) || _MSC_VER >= 1900 AddSSTableRequest::AddSSTableRequest() @@ -26941,6 +26951,11 @@ AddSSTableRequest::AddSSTableRequest(const AddSSTableRequest& from) } else { header_ = NULL; } + if (from.has_mvcc_stats()) { + mvcc_stats_ = new ::cockroach::storage::engine::enginepb::MVCCStats(*from.mvcc_stats_); + } else { + mvcc_stats_ = NULL; + } disallow_shadowing_ = from.disallow_shadowing_; // @@protoc_insertion_point(copy_constructor:cockroach.roachpb.AddSSTableRequest) } @@ -26960,6 +26975,7 @@ AddSSTableRequest::~AddSSTableRequest() { void AddSSTableRequest::SharedDtor() { data_.DestroyNoArena(&::google::protobuf::internal::GetEmptyStringAlreadyInited()); if (this != internal_default_instance()) delete header_; + if (this != internal_default_instance()) delete mvcc_stats_; } void AddSSTableRequest::SetCachedSize(int size) const { @@ -26982,6 +26998,10 @@ void AddSSTableRequest::Clear() { delete header_; } header_ = NULL; + if (GetArenaNoVirtual() == NULL && mvcc_stats_ != NULL) { + delete mvcc_stats_; + } + mvcc_stats_ = NULL; disallow_shadowing_ = false; _internal_metadata_.Clear(); } @@ -27039,6 +27059,17 @@ bool AddSSTableRequest::MergePartialFromCodedStream( break; } + case 4: { + if (static_cast< ::google::protobuf::uint8>(tag) == + static_cast< ::google::protobuf::uint8>(34u /* 34 & 0xFF */)) { + DO_(::google::protobuf::internal::WireFormatLite::ReadMessage( + input, mutable_mvcc_stats())); + } else { + goto handle_unusual; + } + break; + } + default: { handle_unusual: if (tag == 0) { @@ -27081,6 +27112,11 @@ void AddSSTableRequest::SerializeWithCachedSizes( ::google::protobuf::internal::WireFormatLite::WriteBool(3, this->disallow_shadowing(), output); } + if (this->has_mvcc_stats()) { + ::google::protobuf::internal::WireFormatLite::WriteMessage( + 4, this->_internal_mvcc_stats(), output); + } + output->WriteRaw((::google::protobuf::internal::GetProto3PreserveUnknownsDefault() ? _internal_metadata_.unknown_fields() : _internal_metadata_.default_instance()).data(), static_cast((::google::protobuf::internal::GetProto3PreserveUnknownsDefault() ? _internal_metadata_.unknown_fields() : _internal_metadata_.default_instance()).size())); // @@protoc_insertion_point(serialize_end:cockroach.roachpb.AddSSTableRequest) @@ -27105,6 +27141,12 @@ size_t AddSSTableRequest::ByteSizeLong() const { *header_); } + if (this->has_mvcc_stats()) { + total_size += 1 + + ::google::protobuf::internal::WireFormatLite::MessageSize( + *mvcc_stats_); + } + // bool disallow_shadowing = 3; if (this->disallow_shadowing() != 0) { total_size += 1 + 1; @@ -27134,6 +27176,9 @@ void AddSSTableRequest::MergeFrom(const AddSSTableRequest& from) { if (from.has_header()) { mutable_header()->::cockroach::roachpb::RequestHeader::MergeFrom(from.header()); } + if (from.has_mvcc_stats()) { + mutable_mvcc_stats()->::cockroach::storage::engine::enginepb::MVCCStats::MergeFrom(from.mvcc_stats()); + } if (from.disallow_shadowing() != 0) { set_disallow_shadowing(from.disallow_shadowing()); } @@ -27159,6 +27204,7 @@ void AddSSTableRequest::InternalSwap(AddSSTableRequest* other) { data_.Swap(&other->data_, &::google::protobuf::internal::GetEmptyStringAlreadyInited(), GetArenaNoVirtual()); swap(header_, other->header_); + swap(mvcc_stats_, other->mvcc_stats_); swap(disallow_shadowing_, other->disallow_shadowing_); _internal_metadata_.Swap(&other->_internal_metadata_); } diff --git a/c-deps/libroach/protos/roachpb/api.pb.h b/c-deps/libroach/protos/roachpb/api.pb.h index 6c59ff5e9eae..d69afdfb263f 100644 --- a/c-deps/libroach/protos/roachpb/api.pb.h +++ b/c-deps/libroach/protos/roachpb/api.pb.h @@ -12610,6 +12610,17 @@ class AddSSTableRequest : public ::google::protobuf::MessageLite /* @@protoc_ins ::cockroach::roachpb::RequestHeader* mutable_header(); void set_allocated_header(::cockroach::roachpb::RequestHeader* header); + bool has_mvcc_stats() const; + void clear_mvcc_stats(); + static const int kMvccStatsFieldNumber = 4; + private: + const ::cockroach::storage::engine::enginepb::MVCCStats& _internal_mvcc_stats() const; + public: + const ::cockroach::storage::engine::enginepb::MVCCStats& mvcc_stats() const; + ::cockroach::storage::engine::enginepb::MVCCStats* release_mvcc_stats(); + ::cockroach::storage::engine::enginepb::MVCCStats* mutable_mvcc_stats(); + void set_allocated_mvcc_stats(::cockroach::storage::engine::enginepb::MVCCStats* mvcc_stats); + // bool disallow_shadowing = 3; void clear_disallow_shadowing(); static const int kDisallowShadowingFieldNumber = 3; @@ -12622,6 +12633,7 @@ class AddSSTableRequest : public ::google::protobuf::MessageLite /* @@protoc_ins ::google::protobuf::internal::InternalMetadataWithArenaLite _internal_metadata_; ::google::protobuf::internal::ArenaStringPtr data_; ::cockroach::roachpb::RequestHeader* header_; + ::cockroach::storage::engine::enginepb::MVCCStats* mvcc_stats_; bool disallow_shadowing_; mutable ::google::protobuf::internal::CachedSize _cached_size_; friend struct ::protobuf_roachpb_2fapi_2eproto::TableStruct; @@ -27294,6 +27306,53 @@ inline void AddSSTableRequest::set_disallow_shadowing(bool value) { // @@protoc_insertion_point(field_set:cockroach.roachpb.AddSSTableRequest.disallow_shadowing) } +inline bool AddSSTableRequest::has_mvcc_stats() const { + return this != internal_default_instance() && mvcc_stats_ != NULL; +} +inline const ::cockroach::storage::engine::enginepb::MVCCStats& AddSSTableRequest::_internal_mvcc_stats() const { + return *mvcc_stats_; +} +inline const ::cockroach::storage::engine::enginepb::MVCCStats& AddSSTableRequest::mvcc_stats() const { + const ::cockroach::storage::engine::enginepb::MVCCStats* p = mvcc_stats_; + // @@protoc_insertion_point(field_get:cockroach.roachpb.AddSSTableRequest.mvcc_stats) + return p != NULL ? *p : *reinterpret_cast( + &::cockroach::storage::engine::enginepb::_MVCCStats_default_instance_); +} +inline ::cockroach::storage::engine::enginepb::MVCCStats* AddSSTableRequest::release_mvcc_stats() { + // @@protoc_insertion_point(field_release:cockroach.roachpb.AddSSTableRequest.mvcc_stats) + + ::cockroach::storage::engine::enginepb::MVCCStats* temp = mvcc_stats_; + mvcc_stats_ = NULL; + return temp; +} +inline ::cockroach::storage::engine::enginepb::MVCCStats* AddSSTableRequest::mutable_mvcc_stats() { + + if (mvcc_stats_ == NULL) { + auto* p = CreateMaybeMessage<::cockroach::storage::engine::enginepb::MVCCStats>(GetArenaNoVirtual()); + mvcc_stats_ = p; + } + // @@protoc_insertion_point(field_mutable:cockroach.roachpb.AddSSTableRequest.mvcc_stats) + return mvcc_stats_; +} +inline void AddSSTableRequest::set_allocated_mvcc_stats(::cockroach::storage::engine::enginepb::MVCCStats* mvcc_stats) { + ::google::protobuf::Arena* message_arena = GetArenaNoVirtual(); + if (message_arena == NULL) { + delete reinterpret_cast< ::google::protobuf::MessageLite*>(mvcc_stats_); + } + if (mvcc_stats) { + ::google::protobuf::Arena* submessage_arena = NULL; + if (message_arena != submessage_arena) { + mvcc_stats = ::google::protobuf::internal::GetOwnedMessage( + message_arena, mvcc_stats, submessage_arena); + } + + } else { + + } + mvcc_stats_ = mvcc_stats; + // @@protoc_insertion_point(field_set_allocated:cockroach.roachpb.AddSSTableRequest.mvcc_stats) +} + // ------------------------------------------------------------------- // AddSSTableResponse diff --git a/pkg/ccl/importccl/bench_test.go b/pkg/ccl/importccl/bench_test.go index 6bab3b9f3d19..0b83b22a74a4 100644 --- a/pkg/ccl/importccl/bench_test.go +++ b/pkg/ccl/importccl/bench_test.go @@ -134,7 +134,7 @@ func benchmarkAddSSTable(b *testing.B, dir string, tables []tableSSTable) { b.StartTimer() for _, t := range tables { totalBytes += int64(len(t.sstData)) - require.NoError(b, kvDB.AddSSTable(ctx, t.span.Key, t.span.EndKey, t.sstData, true /* disallowShadowing */)) + require.NoError(b, kvDB.AddSSTable(ctx, t.span.Key, t.span.EndKey, t.sstData, true /* disallowShadowing */, nil /* stats */)) } b.StopTimer() diff --git a/pkg/ccl/storageccl/bench_test.go b/pkg/ccl/storageccl/bench_test.go index 0f5e3e2a2250..faf631c9ecf2 100644 --- a/pkg/ccl/storageccl/bench_test.go +++ b/pkg/ccl/storageccl/bench_test.go @@ -77,7 +77,7 @@ func BenchmarkAddSSTable(b *testing.B) { totalLen += int64(len(data)) b.StartTimer() - if err := kvDB.AddSSTable(ctx, span.Key, span.EndKey, data, false /* disallowShadowing */); err != nil { + if err := kvDB.AddSSTable(ctx, span.Key, span.EndKey, data, false /* disallowShadowing */, nil /* stats */); err != nil { b.Fatalf("%+v", err) } b.StopTimer() diff --git a/pkg/ccl/workloadccl/format/sstable.go b/pkg/ccl/workloadccl/format/sstable.go index 9fb8e6a29994..d0d0540a8d2d 100644 --- a/pkg/ccl/workloadccl/format/sstable.go +++ b/pkg/ccl/workloadccl/format/sstable.go @@ -22,6 +22,7 @@ import ( "github.com/cockroachdb/cockroach/pkg/sql/sessiondata" "github.com/cockroachdb/cockroach/pkg/sql/sqlbase" "github.com/cockroachdb/cockroach/pkg/storage/bulk" + "github.com/cockroachdb/cockroach/pkg/storage/engine/enginepb" "github.com/cockroachdb/cockroach/pkg/util/ctxgroup" "github.com/cockroachdb/cockroach/pkg/util/hlc" "github.com/cockroachdb/cockroach/pkg/workload" @@ -105,7 +106,7 @@ func ToSSTable(t workload.Table, tableID sqlbase.ID, ts time.Time) ([]byte, erro type addSSTableSender [][]byte func (s *addSSTableSender) AddSSTable( - _ context.Context, _, _ interface{}, data []byte, _ bool, + _ context.Context, _, _ interface{}, data []byte, _ bool, _ *enginepb.MVCCStats, ) error { *s = append(*s, data) return nil diff --git a/pkg/internal/client/batch.go b/pkg/internal/client/batch.go index 9d9d82721729..f5e2b6bea45d 100644 --- a/pkg/internal/client/batch.go +++ b/pkg/internal/client/batch.go @@ -14,6 +14,7 @@ import ( "context" "github.com/cockroachdb/cockroach/pkg/roachpb" + "github.com/cockroachdb/cockroach/pkg/storage/engine/enginepb" "github.com/cockroachdb/cockroach/pkg/util/hlc" "github.com/pkg/errors" ) @@ -705,7 +706,9 @@ func (b *Batch) writeBatch(s, e interface{}, data []byte) { } // addSSTable is only exported on DB. -func (b *Batch) addSSTable(s, e interface{}, data []byte, disallowShadowing bool) { +func (b *Batch) addSSTable( + s, e interface{}, data []byte, disallowShadowing bool, stats *enginepb.MVCCStats, +) { begin, err := marshalKey(s) if err != nil { b.initResult(0, 0, notRaw, err) @@ -723,6 +726,7 @@ func (b *Batch) addSSTable(s, e interface{}, data []byte, disallowShadowing bool }, Data: data, DisallowShadowing: disallowShadowing, + MVCCStats: stats, } b.appendReqs(req) b.initResult(1, 0, notRaw, nil) diff --git a/pkg/internal/client/db.go b/pkg/internal/client/db.go index b806bcd5109c..8a2394c4ddb3 100644 --- a/pkg/internal/client/db.go +++ b/pkg/internal/client/db.go @@ -17,6 +17,7 @@ import ( "github.com/cockroachdb/cockroach/pkg/base" "github.com/cockroachdb/cockroach/pkg/roachpb" + "github.com/cockroachdb/cockroach/pkg/storage/engine/enginepb" "github.com/cockroachdb/cockroach/pkg/util/hlc" "github.com/cockroachdb/cockroach/pkg/util/log" "github.com/cockroachdb/cockroach/pkg/util/protoutil" @@ -568,10 +569,14 @@ func (db *DB) WriteBatch(ctx context.Context, begin, end interface{}, data []byt // AddSSTable links a file into the RocksDB log-structured merge-tree. Existing // data in the range is cleared. func (db *DB) AddSSTable( - ctx context.Context, begin, end interface{}, data []byte, disallowShadowing bool, + ctx context.Context, + begin, end interface{}, + data []byte, + disallowShadowing bool, + stats *enginepb.MVCCStats, ) error { b := &Batch{} - b.addSSTable(begin, end, data, disallowShadowing) + b.addSSTable(begin, end, data, disallowShadowing, stats) return getOneErr(db.Run(ctx, b), b) } diff --git a/pkg/roachpb/api.pb.go b/pkg/roachpb/api.pb.go index 246f04be2c10..7a2c8ad175e8 100644 --- a/pkg/roachpb/api.pb.go +++ b/pkg/roachpb/api.pb.go @@ -70,7 +70,7 @@ func (x ReadConsistencyType) String() string { return proto.EnumName(ReadConsistencyType_name, int32(x)) } func (ReadConsistencyType) EnumDescriptor() ([]byte, []int) { - return fileDescriptor_api_0e495ec1ebba5dd6, []int{0} + return fileDescriptor_api_e552681b39a41c3e, []int{0} } // ScanFormat is an enumeration of the available response formats for MVCCScan @@ -98,7 +98,7 @@ func (x ScanFormat) String() string { return proto.EnumName(ScanFormat_name, int32(x)) } func (ScanFormat) EnumDescriptor() ([]byte, []int) { - return fileDescriptor_api_0e495ec1ebba5dd6, []int{1} + return fileDescriptor_api_e552681b39a41c3e, []int{1} } type ChecksumMode int32 @@ -145,7 +145,7 @@ func (x ChecksumMode) String() string { return proto.EnumName(ChecksumMode_name, int32(x)) } func (ChecksumMode) EnumDescriptor() ([]byte, []int) { - return fileDescriptor_api_0e495ec1ebba5dd6, []int{2} + return fileDescriptor_api_e552681b39a41c3e, []int{2} } // PushTxnType determines what action to take when pushing a transaction. @@ -176,7 +176,7 @@ func (x PushTxnType) String() string { return proto.EnumName(PushTxnType_name, int32(x)) } func (PushTxnType) EnumDescriptor() ([]byte, []int) { - return fileDescriptor_api_0e495ec1ebba5dd6, []int{3} + return fileDescriptor_api_e552681b39a41c3e, []int{3} } type ExportStorageProvider int32 @@ -214,7 +214,7 @@ func (x ExportStorageProvider) String() string { return proto.EnumName(ExportStorageProvider_name, int32(x)) } func (ExportStorageProvider) EnumDescriptor() ([]byte, []int) { - return fileDescriptor_api_0e495ec1ebba5dd6, []int{4} + return fileDescriptor_api_e552681b39a41c3e, []int{4} } type MVCCFilter int32 @@ -237,7 +237,7 @@ func (x MVCCFilter) String() string { return proto.EnumName(MVCCFilter_name, int32(x)) } func (MVCCFilter) EnumDescriptor() ([]byte, []int) { - return fileDescriptor_api_0e495ec1ebba5dd6, []int{5} + return fileDescriptor_api_e552681b39a41c3e, []int{5} } type ResponseHeader_ResumeReason int32 @@ -269,7 +269,7 @@ func (x ResponseHeader_ResumeReason) String() string { return proto.EnumName(ResponseHeader_ResumeReason_name, int32(x)) } func (ResponseHeader_ResumeReason) EnumDescriptor() ([]byte, []int) { - return fileDescriptor_api_0e495ec1ebba5dd6, []int{2, 0} + return fileDescriptor_api_e552681b39a41c3e, []int{2, 0} } type CheckConsistencyResponse_Status int32 @@ -311,7 +311,7 @@ func (x CheckConsistencyResponse_Status) String() string { return proto.EnumName(CheckConsistencyResponse_Status_name, int32(x)) } func (CheckConsistencyResponse_Status) EnumDescriptor() ([]byte, []int) { - return fileDescriptor_api_0e495ec1ebba5dd6, []int{27, 0} + return fileDescriptor_api_e552681b39a41c3e, []int{27, 0} } // RangeInfo describes a range which executed a request. It contains @@ -325,7 +325,7 @@ func (m *RangeInfo) Reset() { *m = RangeInfo{} } func (m *RangeInfo) String() string { return proto.CompactTextString(m) } func (*RangeInfo) ProtoMessage() {} func (*RangeInfo) Descriptor() ([]byte, []int) { - return fileDescriptor_api_0e495ec1ebba5dd6, []int{0} + return fileDescriptor_api_e552681b39a41c3e, []int{0} } func (m *RangeInfo) XXX_Unmarshal(b []byte) error { return m.Unmarshal(b) @@ -368,7 +368,7 @@ func (m *RequestHeader) Reset() { *m = RequestHeader{} } func (m *RequestHeader) String() string { return proto.CompactTextString(m) } func (*RequestHeader) ProtoMessage() {} func (*RequestHeader) Descriptor() ([]byte, []int) { - return fileDescriptor_api_0e495ec1ebba5dd6, []int{1} + return fileDescriptor_api_e552681b39a41c3e, []int{1} } func (m *RequestHeader) XXX_Unmarshal(b []byte) error { return m.Unmarshal(b) @@ -426,7 +426,7 @@ func (m *ResponseHeader) Reset() { *m = ResponseHeader{} } func (m *ResponseHeader) String() string { return proto.CompactTextString(m) } func (*ResponseHeader) ProtoMessage() {} func (*ResponseHeader) Descriptor() ([]byte, []int) { - return fileDescriptor_api_0e495ec1ebba5dd6, []int{2} + return fileDescriptor_api_e552681b39a41c3e, []int{2} } func (m *ResponseHeader) XXX_Unmarshal(b []byte) error { return m.Unmarshal(b) @@ -460,7 +460,7 @@ func (m *GetRequest) Reset() { *m = GetRequest{} } func (m *GetRequest) String() string { return proto.CompactTextString(m) } func (*GetRequest) ProtoMessage() {} func (*GetRequest) Descriptor() ([]byte, []int) { - return fileDescriptor_api_0e495ec1ebba5dd6, []int{3} + return fileDescriptor_api_e552681b39a41c3e, []int{3} } func (m *GetRequest) XXX_Unmarshal(b []byte) error { return m.Unmarshal(b) @@ -498,7 +498,7 @@ func (m *GetResponse) Reset() { *m = GetResponse{} } func (m *GetResponse) String() string { return proto.CompactTextString(m) } func (*GetResponse) ProtoMessage() {} func (*GetResponse) Descriptor() ([]byte, []int) { - return fileDescriptor_api_0e495ec1ebba5dd6, []int{4} + return fileDescriptor_api_e552681b39a41c3e, []int{4} } func (m *GetResponse) XXX_Unmarshal(b []byte) error { return m.Unmarshal(b) @@ -541,7 +541,7 @@ func (m *PutRequest) Reset() { *m = PutRequest{} } func (m *PutRequest) String() string { return proto.CompactTextString(m) } func (*PutRequest) ProtoMessage() {} func (*PutRequest) Descriptor() ([]byte, []int) { - return fileDescriptor_api_0e495ec1ebba5dd6, []int{5} + return fileDescriptor_api_e552681b39a41c3e, []int{5} } func (m *PutRequest) XXX_Unmarshal(b []byte) error { return m.Unmarshal(b) @@ -575,7 +575,7 @@ func (m *PutResponse) Reset() { *m = PutResponse{} } func (m *PutResponse) String() string { return proto.CompactTextString(m) } func (*PutResponse) ProtoMessage() {} func (*PutResponse) Descriptor() ([]byte, []int) { - return fileDescriptor_api_0e495ec1ebba5dd6, []int{6} + return fileDescriptor_api_e552681b39a41c3e, []int{6} } func (m *PutResponse) XXX_Unmarshal(b []byte) error { return m.Unmarshal(b) @@ -629,7 +629,7 @@ func (m *ConditionalPutRequest) Reset() { *m = ConditionalPutRequest{} } func (m *ConditionalPutRequest) String() string { return proto.CompactTextString(m) } func (*ConditionalPutRequest) ProtoMessage() {} func (*ConditionalPutRequest) Descriptor() ([]byte, []int) { - return fileDescriptor_api_0e495ec1ebba5dd6, []int{7} + return fileDescriptor_api_e552681b39a41c3e, []int{7} } func (m *ConditionalPutRequest) XXX_Unmarshal(b []byte) error { return m.Unmarshal(b) @@ -664,7 +664,7 @@ func (m *ConditionalPutResponse) Reset() { *m = ConditionalPutResponse{} func (m *ConditionalPutResponse) String() string { return proto.CompactTextString(m) } func (*ConditionalPutResponse) ProtoMessage() {} func (*ConditionalPutResponse) Descriptor() ([]byte, []int) { - return fileDescriptor_api_0e495ec1ebba5dd6, []int{8} + return fileDescriptor_api_e552681b39a41c3e, []int{8} } func (m *ConditionalPutResponse) XXX_Unmarshal(b []byte) error { return m.Unmarshal(b) @@ -710,7 +710,7 @@ func (m *InitPutRequest) Reset() { *m = InitPutRequest{} } func (m *InitPutRequest) String() string { return proto.CompactTextString(m) } func (*InitPutRequest) ProtoMessage() {} func (*InitPutRequest) Descriptor() ([]byte, []int) { - return fileDescriptor_api_0e495ec1ebba5dd6, []int{9} + return fileDescriptor_api_e552681b39a41c3e, []int{9} } func (m *InitPutRequest) XXX_Unmarshal(b []byte) error { return m.Unmarshal(b) @@ -744,7 +744,7 @@ func (m *InitPutResponse) Reset() { *m = InitPutResponse{} } func (m *InitPutResponse) String() string { return proto.CompactTextString(m) } func (*InitPutResponse) ProtoMessage() {} func (*InitPutResponse) Descriptor() ([]byte, []int) { - return fileDescriptor_api_0e495ec1ebba5dd6, []int{10} + return fileDescriptor_api_e552681b39a41c3e, []int{10} } func (m *InitPutResponse) XXX_Unmarshal(b []byte) error { return m.Unmarshal(b) @@ -784,7 +784,7 @@ func (m *IncrementRequest) Reset() { *m = IncrementRequest{} } func (m *IncrementRequest) String() string { return proto.CompactTextString(m) } func (*IncrementRequest) ProtoMessage() {} func (*IncrementRequest) Descriptor() ([]byte, []int) { - return fileDescriptor_api_0e495ec1ebba5dd6, []int{11} + return fileDescriptor_api_e552681b39a41c3e, []int{11} } func (m *IncrementRequest) XXX_Unmarshal(b []byte) error { return m.Unmarshal(b) @@ -821,7 +821,7 @@ func (m *IncrementResponse) Reset() { *m = IncrementResponse{} } func (m *IncrementResponse) String() string { return proto.CompactTextString(m) } func (*IncrementResponse) ProtoMessage() {} func (*IncrementResponse) Descriptor() ([]byte, []int) { - return fileDescriptor_api_0e495ec1ebba5dd6, []int{12} + return fileDescriptor_api_e552681b39a41c3e, []int{12} } func (m *IncrementResponse) XXX_Unmarshal(b []byte) error { return m.Unmarshal(b) @@ -855,7 +855,7 @@ func (m *DeleteRequest) Reset() { *m = DeleteRequest{} } func (m *DeleteRequest) String() string { return proto.CompactTextString(m) } func (*DeleteRequest) ProtoMessage() {} func (*DeleteRequest) Descriptor() ([]byte, []int) { - return fileDescriptor_api_0e495ec1ebba5dd6, []int{13} + return fileDescriptor_api_e552681b39a41c3e, []int{13} } func (m *DeleteRequest) XXX_Unmarshal(b []byte) error { return m.Unmarshal(b) @@ -889,7 +889,7 @@ func (m *DeleteResponse) Reset() { *m = DeleteResponse{} } func (m *DeleteResponse) String() string { return proto.CompactTextString(m) } func (*DeleteResponse) ProtoMessage() {} func (*DeleteResponse) Descriptor() ([]byte, []int) { - return fileDescriptor_api_0e495ec1ebba5dd6, []int{14} + return fileDescriptor_api_e552681b39a41c3e, []int{14} } func (m *DeleteResponse) XXX_Unmarshal(b []byte) error { return m.Unmarshal(b) @@ -938,7 +938,7 @@ func (m *DeleteRangeRequest) Reset() { *m = DeleteRangeRequest{} } func (m *DeleteRangeRequest) String() string { return proto.CompactTextString(m) } func (*DeleteRangeRequest) ProtoMessage() {} func (*DeleteRangeRequest) Descriptor() ([]byte, []int) { - return fileDescriptor_api_0e495ec1ebba5dd6, []int{15} + return fileDescriptor_api_e552681b39a41c3e, []int{15} } func (m *DeleteRangeRequest) XXX_Unmarshal(b []byte) error { return m.Unmarshal(b) @@ -975,7 +975,7 @@ func (m *DeleteRangeResponse) Reset() { *m = DeleteRangeResponse{} } func (m *DeleteRangeResponse) String() string { return proto.CompactTextString(m) } func (*DeleteRangeResponse) ProtoMessage() {} func (*DeleteRangeResponse) Descriptor() ([]byte, []int) { - return fileDescriptor_api_0e495ec1ebba5dd6, []int{16} + return fileDescriptor_api_e552681b39a41c3e, []int{16} } func (m *DeleteRangeResponse) XXX_Unmarshal(b []byte) error { return m.Unmarshal(b) @@ -1022,7 +1022,7 @@ func (m *ClearRangeRequest) Reset() { *m = ClearRangeRequest{} } func (m *ClearRangeRequest) String() string { return proto.CompactTextString(m) } func (*ClearRangeRequest) ProtoMessage() {} func (*ClearRangeRequest) Descriptor() ([]byte, []int) { - return fileDescriptor_api_0e495ec1ebba5dd6, []int{17} + return fileDescriptor_api_e552681b39a41c3e, []int{17} } func (m *ClearRangeRequest) XXX_Unmarshal(b []byte) error { return m.Unmarshal(b) @@ -1056,7 +1056,7 @@ func (m *ClearRangeResponse) Reset() { *m = ClearRangeResponse{} } func (m *ClearRangeResponse) String() string { return proto.CompactTextString(m) } func (*ClearRangeResponse) ProtoMessage() {} func (*ClearRangeResponse) Descriptor() ([]byte, []int) { - return fileDescriptor_api_0e495ec1ebba5dd6, []int{18} + return fileDescriptor_api_e552681b39a41c3e, []int{18} } func (m *ClearRangeResponse) XXX_Unmarshal(b []byte) error { return m.Unmarshal(b) @@ -1097,7 +1097,7 @@ func (m *RevertRangeRequest) Reset() { *m = RevertRangeRequest{} } func (m *RevertRangeRequest) String() string { return proto.CompactTextString(m) } func (*RevertRangeRequest) ProtoMessage() {} func (*RevertRangeRequest) Descriptor() ([]byte, []int) { - return fileDescriptor_api_0e495ec1ebba5dd6, []int{19} + return fileDescriptor_api_e552681b39a41c3e, []int{19} } func (m *RevertRangeRequest) XXX_Unmarshal(b []byte) error { return m.Unmarshal(b) @@ -1131,7 +1131,7 @@ func (m *RevertRangeResponse) Reset() { *m = RevertRangeResponse{} } func (m *RevertRangeResponse) String() string { return proto.CompactTextString(m) } func (*RevertRangeResponse) ProtoMessage() {} func (*RevertRangeResponse) Descriptor() ([]byte, []int) { - return fileDescriptor_api_0e495ec1ebba5dd6, []int{20} + return fileDescriptor_api_e552681b39a41c3e, []int{20} } func (m *RevertRangeResponse) XXX_Unmarshal(b []byte) error { return m.Unmarshal(b) @@ -1200,7 +1200,7 @@ func (m *ScanOptions) Reset() { *m = ScanOptions{} } func (m *ScanOptions) String() string { return proto.CompactTextString(m) } func (*ScanOptions) ProtoMessage() {} func (*ScanOptions) Descriptor() ([]byte, []int) { - return fileDescriptor_api_0e495ec1ebba5dd6, []int{21} + return fileDescriptor_api_e552681b39a41c3e, []int{21} } func (m *ScanOptions) XXX_Unmarshal(b []byte) error { return m.Unmarshal(b) @@ -1240,7 +1240,7 @@ func (m *ScanRequest) Reset() { *m = ScanRequest{} } func (m *ScanRequest) String() string { return proto.CompactTextString(m) } func (*ScanRequest) ProtoMessage() {} func (*ScanRequest) Descriptor() ([]byte, []int) { - return fileDescriptor_api_0e495ec1ebba5dd6, []int{22} + return fileDescriptor_api_e552681b39a41c3e, []int{22} } func (m *ScanRequest) XXX_Unmarshal(b []byte) error { return m.Unmarshal(b) @@ -1287,7 +1287,7 @@ func (m *ScanResponse) Reset() { *m = ScanResponse{} } func (m *ScanResponse) String() string { return proto.CompactTextString(m) } func (*ScanResponse) ProtoMessage() {} func (*ScanResponse) Descriptor() ([]byte, []int) { - return fileDescriptor_api_0e495ec1ebba5dd6, []int{23} + return fileDescriptor_api_e552681b39a41c3e, []int{23} } func (m *ScanResponse) XXX_Unmarshal(b []byte) error { return m.Unmarshal(b) @@ -1327,7 +1327,7 @@ func (m *ReverseScanRequest) Reset() { *m = ReverseScanRequest{} } func (m *ReverseScanRequest) String() string { return proto.CompactTextString(m) } func (*ReverseScanRequest) ProtoMessage() {} func (*ReverseScanRequest) Descriptor() ([]byte, []int) { - return fileDescriptor_api_0e495ec1ebba5dd6, []int{24} + return fileDescriptor_api_e552681b39a41c3e, []int{24} } func (m *ReverseScanRequest) XXX_Unmarshal(b []byte) error { return m.Unmarshal(b) @@ -1374,7 +1374,7 @@ func (m *ReverseScanResponse) Reset() { *m = ReverseScanResponse{} } func (m *ReverseScanResponse) String() string { return proto.CompactTextString(m) } func (*ReverseScanResponse) ProtoMessage() {} func (*ReverseScanResponse) Descriptor() ([]byte, []int) { - return fileDescriptor_api_0e495ec1ebba5dd6, []int{25} + return fileDescriptor_api_e552681b39a41c3e, []int{25} } func (m *ReverseScanResponse) XXX_Unmarshal(b []byte) error { return m.Unmarshal(b) @@ -1420,7 +1420,7 @@ func (m *CheckConsistencyRequest) Reset() { *m = CheckConsistencyRequest func (m *CheckConsistencyRequest) String() string { return proto.CompactTextString(m) } func (*CheckConsistencyRequest) ProtoMessage() {} func (*CheckConsistencyRequest) Descriptor() ([]byte, []int) { - return fileDescriptor_api_0e495ec1ebba5dd6, []int{26} + return fileDescriptor_api_e552681b39a41c3e, []int{26} } func (m *CheckConsistencyRequest) XXX_Unmarshal(b []byte) error { return m.Unmarshal(b) @@ -1457,7 +1457,7 @@ func (m *CheckConsistencyResponse) Reset() { *m = CheckConsistencyRespon func (m *CheckConsistencyResponse) String() string { return proto.CompactTextString(m) } func (*CheckConsistencyResponse) ProtoMessage() {} func (*CheckConsistencyResponse) Descriptor() ([]byte, []int) { - return fileDescriptor_api_0e495ec1ebba5dd6, []int{27} + return fileDescriptor_api_e552681b39a41c3e, []int{27} } func (m *CheckConsistencyResponse) XXX_Unmarshal(b []byte) error { return m.Unmarshal(b) @@ -1501,7 +1501,7 @@ func (m *CheckConsistencyResponse_Result) Reset() { *m = CheckConsistenc func (m *CheckConsistencyResponse_Result) String() string { return proto.CompactTextString(m) } func (*CheckConsistencyResponse_Result) ProtoMessage() {} func (*CheckConsistencyResponse_Result) Descriptor() ([]byte, []int) { - return fileDescriptor_api_0e495ec1ebba5dd6, []int{27, 0} + return fileDescriptor_api_e552681b39a41c3e, []int{27, 0} } func (m *CheckConsistencyResponse_Result) XXX_Unmarshal(b []byte) error { return m.Unmarshal(b) @@ -1549,7 +1549,7 @@ func (m *RecomputeStatsRequest) Reset() { *m = RecomputeStatsRequest{} } func (m *RecomputeStatsRequest) String() string { return proto.CompactTextString(m) } func (*RecomputeStatsRequest) ProtoMessage() {} func (*RecomputeStatsRequest) Descriptor() ([]byte, []int) { - return fileDescriptor_api_0e495ec1ebba5dd6, []int{28} + return fileDescriptor_api_e552681b39a41c3e, []int{28} } func (m *RecomputeStatsRequest) XXX_Unmarshal(b []byte) error { return m.Unmarshal(b) @@ -1585,7 +1585,7 @@ func (m *RecomputeStatsResponse) Reset() { *m = RecomputeStatsResponse{} func (m *RecomputeStatsResponse) String() string { return proto.CompactTextString(m) } func (*RecomputeStatsResponse) ProtoMessage() {} func (*RecomputeStatsResponse) Descriptor() ([]byte, []int) { - return fileDescriptor_api_0e495ec1ebba5dd6, []int{29} + return fileDescriptor_api_e552681b39a41c3e, []int{29} } func (m *RecomputeStatsResponse) XXX_Unmarshal(b []byte) error { return m.Unmarshal(b) @@ -1619,7 +1619,7 @@ func (m *BeginTransactionRequest) Reset() { *m = BeginTransactionRequest func (m *BeginTransactionRequest) String() string { return proto.CompactTextString(m) } func (*BeginTransactionRequest) ProtoMessage() {} func (*BeginTransactionRequest) Descriptor() ([]byte, []int) { - return fileDescriptor_api_0e495ec1ebba5dd6, []int{30} + return fileDescriptor_api_e552681b39a41c3e, []int{30} } func (m *BeginTransactionRequest) XXX_Unmarshal(b []byte) error { return m.Unmarshal(b) @@ -1653,7 +1653,7 @@ func (m *BeginTransactionResponse) Reset() { *m = BeginTransactionRespon func (m *BeginTransactionResponse) String() string { return proto.CompactTextString(m) } func (*BeginTransactionResponse) ProtoMessage() {} func (*BeginTransactionResponse) Descriptor() ([]byte, []int) { - return fileDescriptor_api_0e495ec1ebba5dd6, []int{31} + return fileDescriptor_api_e552681b39a41c3e, []int{31} } func (m *BeginTransactionResponse) XXX_Unmarshal(b []byte) error { return m.Unmarshal(b) @@ -1741,7 +1741,7 @@ func (m *EndTransactionRequest) Reset() { *m = EndTransactionRequest{} } func (m *EndTransactionRequest) String() string { return proto.CompactTextString(m) } func (*EndTransactionRequest) ProtoMessage() {} func (*EndTransactionRequest) Descriptor() ([]byte, []int) { - return fileDescriptor_api_0e495ec1ebba5dd6, []int{32} + return fileDescriptor_api_e552681b39a41c3e, []int{32} } func (m *EndTransactionRequest) XXX_Unmarshal(b []byte) error { return m.Unmarshal(b) @@ -1788,7 +1788,7 @@ func (m *EndTransactionResponse) Reset() { *m = EndTransactionResponse{} func (m *EndTransactionResponse) String() string { return proto.CompactTextString(m) } func (*EndTransactionResponse) ProtoMessage() {} func (*EndTransactionResponse) Descriptor() ([]byte, []int) { - return fileDescriptor_api_0e495ec1ebba5dd6, []int{33} + return fileDescriptor_api_e552681b39a41c3e, []int{33} } func (m *EndTransactionResponse) XXX_Unmarshal(b []byte) error { return m.Unmarshal(b) @@ -1849,7 +1849,7 @@ func (m *AdminSplitRequest) Reset() { *m = AdminSplitRequest{} } func (m *AdminSplitRequest) String() string { return proto.CompactTextString(m) } func (*AdminSplitRequest) ProtoMessage() {} func (*AdminSplitRequest) Descriptor() ([]byte, []int) { - return fileDescriptor_api_0e495ec1ebba5dd6, []int{34} + return fileDescriptor_api_e552681b39a41c3e, []int{34} } func (m *AdminSplitRequest) XXX_Unmarshal(b []byte) error { return m.Unmarshal(b) @@ -1884,7 +1884,7 @@ func (m *AdminSplitResponse) Reset() { *m = AdminSplitResponse{} } func (m *AdminSplitResponse) String() string { return proto.CompactTextString(m) } func (*AdminSplitResponse) ProtoMessage() {} func (*AdminSplitResponse) Descriptor() ([]byte, []int) { - return fileDescriptor_api_0e495ec1ebba5dd6, []int{35} + return fileDescriptor_api_e552681b39a41c3e, []int{35} } func (m *AdminSplitResponse) XXX_Unmarshal(b []byte) error { return m.Unmarshal(b) @@ -1923,7 +1923,7 @@ func (m *AdminUnsplitRequest) Reset() { *m = AdminUnsplitRequest{} } func (m *AdminUnsplitRequest) String() string { return proto.CompactTextString(m) } func (*AdminUnsplitRequest) ProtoMessage() {} func (*AdminUnsplitRequest) Descriptor() ([]byte, []int) { - return fileDescriptor_api_0e495ec1ebba5dd6, []int{36} + return fileDescriptor_api_e552681b39a41c3e, []int{36} } func (m *AdminUnsplitRequest) XXX_Unmarshal(b []byte) error { return m.Unmarshal(b) @@ -1958,7 +1958,7 @@ func (m *AdminUnsplitResponse) Reset() { *m = AdminUnsplitResponse{} } func (m *AdminUnsplitResponse) String() string { return proto.CompactTextString(m) } func (*AdminUnsplitResponse) ProtoMessage() {} func (*AdminUnsplitResponse) Descriptor() ([]byte, []int) { - return fileDescriptor_api_0e495ec1ebba5dd6, []int{37} + return fileDescriptor_api_e552681b39a41c3e, []int{37} } func (m *AdminUnsplitResponse) XXX_Unmarshal(b []byte) error { return m.Unmarshal(b) @@ -2000,7 +2000,7 @@ func (m *AdminMergeRequest) Reset() { *m = AdminMergeRequest{} } func (m *AdminMergeRequest) String() string { return proto.CompactTextString(m) } func (*AdminMergeRequest) ProtoMessage() {} func (*AdminMergeRequest) Descriptor() ([]byte, []int) { - return fileDescriptor_api_0e495ec1ebba5dd6, []int{38} + return fileDescriptor_api_e552681b39a41c3e, []int{38} } func (m *AdminMergeRequest) XXX_Unmarshal(b []byte) error { return m.Unmarshal(b) @@ -2035,7 +2035,7 @@ func (m *AdminMergeResponse) Reset() { *m = AdminMergeResponse{} } func (m *AdminMergeResponse) String() string { return proto.CompactTextString(m) } func (*AdminMergeResponse) ProtoMessage() {} func (*AdminMergeResponse) Descriptor() ([]byte, []int) { - return fileDescriptor_api_0e495ec1ebba5dd6, []int{39} + return fileDescriptor_api_e552681b39a41c3e, []int{39} } func (m *AdminMergeResponse) XXX_Unmarshal(b []byte) error { return m.Unmarshal(b) @@ -2073,7 +2073,7 @@ func (m *AdminTransferLeaseRequest) Reset() { *m = AdminTransferLeaseReq func (m *AdminTransferLeaseRequest) String() string { return proto.CompactTextString(m) } func (*AdminTransferLeaseRequest) ProtoMessage() {} func (*AdminTransferLeaseRequest) Descriptor() ([]byte, []int) { - return fileDescriptor_api_0e495ec1ebba5dd6, []int{40} + return fileDescriptor_api_e552681b39a41c3e, []int{40} } func (m *AdminTransferLeaseRequest) XXX_Unmarshal(b []byte) error { return m.Unmarshal(b) @@ -2106,7 +2106,7 @@ func (m *AdminTransferLeaseResponse) Reset() { *m = AdminTransferLeaseRe func (m *AdminTransferLeaseResponse) String() string { return proto.CompactTextString(m) } func (*AdminTransferLeaseResponse) ProtoMessage() {} func (*AdminTransferLeaseResponse) Descriptor() ([]byte, []int) { - return fileDescriptor_api_0e495ec1ebba5dd6, []int{41} + return fileDescriptor_api_e552681b39a41c3e, []int{41} } func (m *AdminTransferLeaseResponse) XXX_Unmarshal(b []byte) error { return m.Unmarshal(b) @@ -2154,7 +2154,7 @@ func (m *AdminChangeReplicasRequest) Reset() { *m = AdminChangeReplicasR func (m *AdminChangeReplicasRequest) String() string { return proto.CompactTextString(m) } func (*AdminChangeReplicasRequest) ProtoMessage() {} func (*AdminChangeReplicasRequest) Descriptor() ([]byte, []int) { - return fileDescriptor_api_0e495ec1ebba5dd6, []int{42} + return fileDescriptor_api_e552681b39a41c3e, []int{42} } func (m *AdminChangeReplicasRequest) XXX_Unmarshal(b []byte) error { return m.Unmarshal(b) @@ -2189,7 +2189,7 @@ func (m *AdminChangeReplicasResponse) Reset() { *m = AdminChangeReplicas func (m *AdminChangeReplicasResponse) String() string { return proto.CompactTextString(m) } func (*AdminChangeReplicasResponse) ProtoMessage() {} func (*AdminChangeReplicasResponse) Descriptor() ([]byte, []int) { - return fileDescriptor_api_0e495ec1ebba5dd6, []int{43} + return fileDescriptor_api_e552681b39a41c3e, []int{43} } func (m *AdminChangeReplicasResponse) XXX_Unmarshal(b []byte) error { return m.Unmarshal(b) @@ -2226,7 +2226,7 @@ func (m *AdminRelocateRangeRequest) Reset() { *m = AdminRelocateRangeReq func (m *AdminRelocateRangeRequest) String() string { return proto.CompactTextString(m) } func (*AdminRelocateRangeRequest) ProtoMessage() {} func (*AdminRelocateRangeRequest) Descriptor() ([]byte, []int) { - return fileDescriptor_api_0e495ec1ebba5dd6, []int{44} + return fileDescriptor_api_e552681b39a41c3e, []int{44} } func (m *AdminRelocateRangeRequest) XXX_Unmarshal(b []byte) error { return m.Unmarshal(b) @@ -2259,7 +2259,7 @@ func (m *AdminRelocateRangeResponse) Reset() { *m = AdminRelocateRangeRe func (m *AdminRelocateRangeResponse) String() string { return proto.CompactTextString(m) } func (*AdminRelocateRangeResponse) ProtoMessage() {} func (*AdminRelocateRangeResponse) Descriptor() ([]byte, []int) { - return fileDescriptor_api_0e495ec1ebba5dd6, []int{45} + return fileDescriptor_api_e552681b39a41c3e, []int{45} } func (m *AdminRelocateRangeResponse) XXX_Unmarshal(b []byte) error { return m.Unmarshal(b) @@ -2298,7 +2298,7 @@ func (m *HeartbeatTxnRequest) Reset() { *m = HeartbeatTxnRequest{} } func (m *HeartbeatTxnRequest) String() string { return proto.CompactTextString(m) } func (*HeartbeatTxnRequest) ProtoMessage() {} func (*HeartbeatTxnRequest) Descriptor() ([]byte, []int) { - return fileDescriptor_api_0e495ec1ebba5dd6, []int{46} + return fileDescriptor_api_e552681b39a41c3e, []int{46} } func (m *HeartbeatTxnRequest) XXX_Unmarshal(b []byte) error { return m.Unmarshal(b) @@ -2335,7 +2335,7 @@ func (m *HeartbeatTxnResponse) Reset() { *m = HeartbeatTxnResponse{} } func (m *HeartbeatTxnResponse) String() string { return proto.CompactTextString(m) } func (*HeartbeatTxnResponse) ProtoMessage() {} func (*HeartbeatTxnResponse) Descriptor() ([]byte, []int) { - return fileDescriptor_api_0e495ec1ebba5dd6, []int{47} + return fileDescriptor_api_e552681b39a41c3e, []int{47} } func (m *HeartbeatTxnResponse) XXX_Unmarshal(b []byte) error { return m.Unmarshal(b) @@ -2373,7 +2373,7 @@ func (m *GCRequest) Reset() { *m = GCRequest{} } func (m *GCRequest) String() string { return proto.CompactTextString(m) } func (*GCRequest) ProtoMessage() {} func (*GCRequest) Descriptor() ([]byte, []int) { - return fileDescriptor_api_0e495ec1ebba5dd6, []int{48} + return fileDescriptor_api_e552681b39a41c3e, []int{48} } func (m *GCRequest) XXX_Unmarshal(b []byte) error { return m.Unmarshal(b) @@ -2407,7 +2407,7 @@ func (m *GCRequest_GCKey) Reset() { *m = GCRequest_GCKey{} } func (m *GCRequest_GCKey) String() string { return proto.CompactTextString(m) } func (*GCRequest_GCKey) ProtoMessage() {} func (*GCRequest_GCKey) Descriptor() ([]byte, []int) { - return fileDescriptor_api_0e495ec1ebba5dd6, []int{48, 0} + return fileDescriptor_api_e552681b39a41c3e, []int{48, 0} } func (m *GCRequest_GCKey) XXX_Unmarshal(b []byte) error { return m.Unmarshal(b) @@ -2441,7 +2441,7 @@ func (m *GCResponse) Reset() { *m = GCResponse{} } func (m *GCResponse) String() string { return proto.CompactTextString(m) } func (*GCResponse) ProtoMessage() {} func (*GCResponse) Descriptor() ([]byte, []int) { - return fileDescriptor_api_0e495ec1ebba5dd6, []int{49} + return fileDescriptor_api_e552681b39a41c3e, []int{49} } func (m *GCResponse) XXX_Unmarshal(b []byte) error { return m.Unmarshal(b) @@ -2516,7 +2516,7 @@ func (m *PushTxnRequest) Reset() { *m = PushTxnRequest{} } func (m *PushTxnRequest) String() string { return proto.CompactTextString(m) } func (*PushTxnRequest) ProtoMessage() {} func (*PushTxnRequest) Descriptor() ([]byte, []int) { - return fileDescriptor_api_0e495ec1ebba5dd6, []int{50} + return fileDescriptor_api_e552681b39a41c3e, []int{50} } func (m *PushTxnRequest) XXX_Unmarshal(b []byte) error { return m.Unmarshal(b) @@ -2559,7 +2559,7 @@ func (m *PushTxnResponse) Reset() { *m = PushTxnResponse{} } func (m *PushTxnResponse) String() string { return proto.CompactTextString(m) } func (*PushTxnResponse) ProtoMessage() {} func (*PushTxnResponse) Descriptor() ([]byte, []int) { - return fileDescriptor_api_0e495ec1ebba5dd6, []int{51} + return fileDescriptor_api_e552681b39a41c3e, []int{51} } func (m *PushTxnResponse) XXX_Unmarshal(b []byte) error { return m.Unmarshal(b) @@ -2606,7 +2606,7 @@ func (m *RecoverTxnRequest) Reset() { *m = RecoverTxnRequest{} } func (m *RecoverTxnRequest) String() string { return proto.CompactTextString(m) } func (*RecoverTxnRequest) ProtoMessage() {} func (*RecoverTxnRequest) Descriptor() ([]byte, []int) { - return fileDescriptor_api_0e495ec1ebba5dd6, []int{52} + return fileDescriptor_api_e552681b39a41c3e, []int{52} } func (m *RecoverTxnRequest) XXX_Unmarshal(b []byte) error { return m.Unmarshal(b) @@ -2642,7 +2642,7 @@ func (m *RecoverTxnResponse) Reset() { *m = RecoverTxnResponse{} } func (m *RecoverTxnResponse) String() string { return proto.CompactTextString(m) } func (*RecoverTxnResponse) ProtoMessage() {} func (*RecoverTxnResponse) Descriptor() ([]byte, []int) { - return fileDescriptor_api_0e495ec1ebba5dd6, []int{53} + return fileDescriptor_api_e552681b39a41c3e, []int{53} } func (m *RecoverTxnResponse) XXX_Unmarshal(b []byte) error { return m.Unmarshal(b) @@ -2686,7 +2686,7 @@ func (m *QueryTxnRequest) Reset() { *m = QueryTxnRequest{} } func (m *QueryTxnRequest) String() string { return proto.CompactTextString(m) } func (*QueryTxnRequest) ProtoMessage() {} func (*QueryTxnRequest) Descriptor() ([]byte, []int) { - return fileDescriptor_api_0e495ec1ebba5dd6, []int{54} + return fileDescriptor_api_e552681b39a41c3e, []int{54} } func (m *QueryTxnRequest) XXX_Unmarshal(b []byte) error { return m.Unmarshal(b) @@ -2725,7 +2725,7 @@ func (m *QueryTxnResponse) Reset() { *m = QueryTxnResponse{} } func (m *QueryTxnResponse) String() string { return proto.CompactTextString(m) } func (*QueryTxnResponse) ProtoMessage() {} func (*QueryTxnResponse) Descriptor() ([]byte, []int) { - return fileDescriptor_api_0e495ec1ebba5dd6, []int{55} + return fileDescriptor_api_e552681b39a41c3e, []int{55} } func (m *QueryTxnResponse) XXX_Unmarshal(b []byte) error { return m.Unmarshal(b) @@ -2785,7 +2785,7 @@ func (m *QueryIntentRequest) Reset() { *m = QueryIntentRequest{} } func (m *QueryIntentRequest) String() string { return proto.CompactTextString(m) } func (*QueryIntentRequest) ProtoMessage() {} func (*QueryIntentRequest) Descriptor() ([]byte, []int) { - return fileDescriptor_api_0e495ec1ebba5dd6, []int{56} + return fileDescriptor_api_e552681b39a41c3e, []int{56} } func (m *QueryIntentRequest) XXX_Unmarshal(b []byte) error { return m.Unmarshal(b) @@ -2821,7 +2821,7 @@ func (m *QueryIntentResponse) Reset() { *m = QueryIntentResponse{} } func (m *QueryIntentResponse) String() string { return proto.CompactTextString(m) } func (*QueryIntentResponse) ProtoMessage() {} func (*QueryIntentResponse) Descriptor() ([]byte, []int) { - return fileDescriptor_api_0e495ec1ebba5dd6, []int{57} + return fileDescriptor_api_e552681b39a41c3e, []int{57} } func (m *QueryIntentResponse) XXX_Unmarshal(b []byte) error { return m.Unmarshal(b) @@ -2865,7 +2865,7 @@ func (m *ResolveIntentRequest) Reset() { *m = ResolveIntentRequest{} } func (m *ResolveIntentRequest) String() string { return proto.CompactTextString(m) } func (*ResolveIntentRequest) ProtoMessage() {} func (*ResolveIntentRequest) Descriptor() ([]byte, []int) { - return fileDescriptor_api_0e495ec1ebba5dd6, []int{58} + return fileDescriptor_api_e552681b39a41c3e, []int{58} } func (m *ResolveIntentRequest) XXX_Unmarshal(b []byte) error { return m.Unmarshal(b) @@ -2900,7 +2900,7 @@ func (m *ResolveIntentResponse) Reset() { *m = ResolveIntentResponse{} } func (m *ResolveIntentResponse) String() string { return proto.CompactTextString(m) } func (*ResolveIntentResponse) ProtoMessage() {} func (*ResolveIntentResponse) Descriptor() ([]byte, []int) { - return fileDescriptor_api_0e495ec1ebba5dd6, []int{59} + return fileDescriptor_api_e552681b39a41c3e, []int{59} } func (m *ResolveIntentResponse) XXX_Unmarshal(b []byte) error { return m.Unmarshal(b) @@ -2948,7 +2948,7 @@ func (m *ResolveIntentRangeRequest) Reset() { *m = ResolveIntentRangeReq func (m *ResolveIntentRangeRequest) String() string { return proto.CompactTextString(m) } func (*ResolveIntentRangeRequest) ProtoMessage() {} func (*ResolveIntentRangeRequest) Descriptor() ([]byte, []int) { - return fileDescriptor_api_0e495ec1ebba5dd6, []int{60} + return fileDescriptor_api_e552681b39a41c3e, []int{60} } func (m *ResolveIntentRangeRequest) XXX_Unmarshal(b []byte) error { return m.Unmarshal(b) @@ -2983,7 +2983,7 @@ func (m *ResolveIntentRangeResponse) Reset() { *m = ResolveIntentRangeRe func (m *ResolveIntentRangeResponse) String() string { return proto.CompactTextString(m) } func (*ResolveIntentRangeResponse) ProtoMessage() {} func (*ResolveIntentRangeResponse) Descriptor() ([]byte, []int) { - return fileDescriptor_api_0e495ec1ebba5dd6, []int{61} + return fileDescriptor_api_e552681b39a41c3e, []int{61} } func (m *ResolveIntentRangeResponse) XXX_Unmarshal(b []byte) error { return m.Unmarshal(b) @@ -3020,7 +3020,7 @@ func (m *MergeRequest) Reset() { *m = MergeRequest{} } func (m *MergeRequest) String() string { return proto.CompactTextString(m) } func (*MergeRequest) ProtoMessage() {} func (*MergeRequest) Descriptor() ([]byte, []int) { - return fileDescriptor_api_0e495ec1ebba5dd6, []int{62} + return fileDescriptor_api_e552681b39a41c3e, []int{62} } func (m *MergeRequest) XXX_Unmarshal(b []byte) error { return m.Unmarshal(b) @@ -3054,7 +3054,7 @@ func (m *MergeResponse) Reset() { *m = MergeResponse{} } func (m *MergeResponse) String() string { return proto.CompactTextString(m) } func (*MergeResponse) ProtoMessage() {} func (*MergeResponse) Descriptor() ([]byte, []int) { - return fileDescriptor_api_0e495ec1ebba5dd6, []int{63} + return fileDescriptor_api_e552681b39a41c3e, []int{63} } func (m *MergeResponse) XXX_Unmarshal(b []byte) error { return m.Unmarshal(b) @@ -3099,7 +3099,7 @@ func (m *TruncateLogRequest) Reset() { *m = TruncateLogRequest{} } func (m *TruncateLogRequest) String() string { return proto.CompactTextString(m) } func (*TruncateLogRequest) ProtoMessage() {} func (*TruncateLogRequest) Descriptor() ([]byte, []int) { - return fileDescriptor_api_0e495ec1ebba5dd6, []int{64} + return fileDescriptor_api_e552681b39a41c3e, []int{64} } func (m *TruncateLogRequest) XXX_Unmarshal(b []byte) error { return m.Unmarshal(b) @@ -3133,7 +3133,7 @@ func (m *TruncateLogResponse) Reset() { *m = TruncateLogResponse{} } func (m *TruncateLogResponse) String() string { return proto.CompactTextString(m) } func (*TruncateLogResponse) ProtoMessage() {} func (*TruncateLogResponse) Descriptor() ([]byte, []int) { - return fileDescriptor_api_0e495ec1ebba5dd6, []int{65} + return fileDescriptor_api_e552681b39a41c3e, []int{65} } func (m *TruncateLogResponse) XXX_Unmarshal(b []byte) error { return m.Unmarshal(b) @@ -3177,7 +3177,7 @@ func (m *RequestLeaseRequest) Reset() { *m = RequestLeaseRequest{} } func (m *RequestLeaseRequest) String() string { return proto.CompactTextString(m) } func (*RequestLeaseRequest) ProtoMessage() {} func (*RequestLeaseRequest) Descriptor() ([]byte, []int) { - return fileDescriptor_api_0e495ec1ebba5dd6, []int{66} + return fileDescriptor_api_e552681b39a41c3e, []int{66} } func (m *RequestLeaseRequest) XXX_Unmarshal(b []byte) error { return m.Unmarshal(b) @@ -3226,7 +3226,7 @@ func (m *TransferLeaseRequest) Reset() { *m = TransferLeaseRequest{} } func (m *TransferLeaseRequest) String() string { return proto.CompactTextString(m) } func (*TransferLeaseRequest) ProtoMessage() {} func (*TransferLeaseRequest) Descriptor() ([]byte, []int) { - return fileDescriptor_api_0e495ec1ebba5dd6, []int{67} + return fileDescriptor_api_e552681b39a41c3e, []int{67} } func (m *TransferLeaseRequest) XXX_Unmarshal(b []byte) error { return m.Unmarshal(b) @@ -3263,7 +3263,7 @@ func (m *LeaseInfoRequest) Reset() { *m = LeaseInfoRequest{} } func (m *LeaseInfoRequest) String() string { return proto.CompactTextString(m) } func (*LeaseInfoRequest) ProtoMessage() {} func (*LeaseInfoRequest) Descriptor() ([]byte, []int) { - return fileDescriptor_api_0e495ec1ebba5dd6, []int{68} + return fileDescriptor_api_e552681b39a41c3e, []int{68} } func (m *LeaseInfoRequest) XXX_Unmarshal(b []byte) error { return m.Unmarshal(b) @@ -3300,7 +3300,7 @@ func (m *LeaseInfoResponse) Reset() { *m = LeaseInfoResponse{} } func (m *LeaseInfoResponse) String() string { return proto.CompactTextString(m) } func (*LeaseInfoResponse) ProtoMessage() {} func (*LeaseInfoResponse) Descriptor() ([]byte, []int) { - return fileDescriptor_api_0e495ec1ebba5dd6, []int{69} + return fileDescriptor_api_e552681b39a41c3e, []int{69} } func (m *LeaseInfoResponse) XXX_Unmarshal(b []byte) error { return m.Unmarshal(b) @@ -3335,7 +3335,7 @@ func (m *RequestLeaseResponse) Reset() { *m = RequestLeaseResponse{} } func (m *RequestLeaseResponse) String() string { return proto.CompactTextString(m) } func (*RequestLeaseResponse) ProtoMessage() {} func (*RequestLeaseResponse) Descriptor() ([]byte, []int) { - return fileDescriptor_api_0e495ec1ebba5dd6, []int{70} + return fileDescriptor_api_e552681b39a41c3e, []int{70} } func (m *RequestLeaseResponse) XXX_Unmarshal(b []byte) error { return m.Unmarshal(b) @@ -3385,7 +3385,7 @@ func (m *ComputeChecksumRequest) Reset() { *m = ComputeChecksumRequest{} func (m *ComputeChecksumRequest) String() string { return proto.CompactTextString(m) } func (*ComputeChecksumRequest) ProtoMessage() {} func (*ComputeChecksumRequest) Descriptor() ([]byte, []int) { - return fileDescriptor_api_0e495ec1ebba5dd6, []int{71} + return fileDescriptor_api_e552681b39a41c3e, []int{71} } func (m *ComputeChecksumRequest) XXX_Unmarshal(b []byte) error { return m.Unmarshal(b) @@ -3422,7 +3422,7 @@ func (m *ComputeChecksumResponse) Reset() { *m = ComputeChecksumResponse func (m *ComputeChecksumResponse) String() string { return proto.CompactTextString(m) } func (*ComputeChecksumResponse) ProtoMessage() {} func (*ComputeChecksumResponse) Descriptor() ([]byte, []int) { - return fileDescriptor_api_0e495ec1ebba5dd6, []int{72} + return fileDescriptor_api_e552681b39a41c3e, []int{72} } func (m *ComputeChecksumResponse) XXX_Unmarshal(b []byte) error { return m.Unmarshal(b) @@ -3461,7 +3461,7 @@ func (m *ExportStorage) Reset() { *m = ExportStorage{} } func (m *ExportStorage) String() string { return proto.CompactTextString(m) } func (*ExportStorage) ProtoMessage() {} func (*ExportStorage) Descriptor() ([]byte, []int) { - return fileDescriptor_api_0e495ec1ebba5dd6, []int{73} + return fileDescriptor_api_e552681b39a41c3e, []int{73} } func (m *ExportStorage) XXX_Unmarshal(b []byte) error { return m.Unmarshal(b) @@ -3495,7 +3495,7 @@ func (m *ExportStorage_LocalFilePath) Reset() { *m = ExportStorage_Local func (m *ExportStorage_LocalFilePath) String() string { return proto.CompactTextString(m) } func (*ExportStorage_LocalFilePath) ProtoMessage() {} func (*ExportStorage_LocalFilePath) Descriptor() ([]byte, []int) { - return fileDescriptor_api_0e495ec1ebba5dd6, []int{73, 0} + return fileDescriptor_api_e552681b39a41c3e, []int{73, 0} } func (m *ExportStorage_LocalFilePath) XXX_Unmarshal(b []byte) error { return m.Unmarshal(b) @@ -3528,7 +3528,7 @@ func (m *ExportStorage_Http) Reset() { *m = ExportStorage_Http{} } func (m *ExportStorage_Http) String() string { return proto.CompactTextString(m) } func (*ExportStorage_Http) ProtoMessage() {} func (*ExportStorage_Http) Descriptor() ([]byte, []int) { - return fileDescriptor_api_0e495ec1ebba5dd6, []int{73, 1} + return fileDescriptor_api_e552681b39a41c3e, []int{73, 1} } func (m *ExportStorage_Http) XXX_Unmarshal(b []byte) error { return m.Unmarshal(b) @@ -3567,7 +3567,7 @@ func (m *ExportStorage_S3) Reset() { *m = ExportStorage_S3{} } func (m *ExportStorage_S3) String() string { return proto.CompactTextString(m) } func (*ExportStorage_S3) ProtoMessage() {} func (*ExportStorage_S3) Descriptor() ([]byte, []int) { - return fileDescriptor_api_0e495ec1ebba5dd6, []int{73, 2} + return fileDescriptor_api_e552681b39a41c3e, []int{73, 2} } func (m *ExportStorage_S3) XXX_Unmarshal(b []byte) error { return m.Unmarshal(b) @@ -3606,7 +3606,7 @@ func (m *ExportStorage_GCS) Reset() { *m = ExportStorage_GCS{} } func (m *ExportStorage_GCS) String() string { return proto.CompactTextString(m) } func (*ExportStorage_GCS) ProtoMessage() {} func (*ExportStorage_GCS) Descriptor() ([]byte, []int) { - return fileDescriptor_api_0e495ec1ebba5dd6, []int{73, 3} + return fileDescriptor_api_e552681b39a41c3e, []int{73, 3} } func (m *ExportStorage_GCS) XXX_Unmarshal(b []byte) error { return m.Unmarshal(b) @@ -3642,7 +3642,7 @@ func (m *ExportStorage_Azure) Reset() { *m = ExportStorage_Azure{} } func (m *ExportStorage_Azure) String() string { return proto.CompactTextString(m) } func (*ExportStorage_Azure) ProtoMessage() {} func (*ExportStorage_Azure) Descriptor() ([]byte, []int) { - return fileDescriptor_api_0e495ec1ebba5dd6, []int{73, 4} + return fileDescriptor_api_e552681b39a41c3e, []int{73, 4} } func (m *ExportStorage_Azure) XXX_Unmarshal(b []byte) error { return m.Unmarshal(b) @@ -3681,7 +3681,7 @@ func (m *ExportStorage_Workload) Reset() { *m = ExportStorage_Workload{} func (m *ExportStorage_Workload) String() string { return proto.CompactTextString(m) } func (*ExportStorage_Workload) ProtoMessage() {} func (*ExportStorage_Workload) Descriptor() ([]byte, []int) { - return fileDescriptor_api_0e495ec1ebba5dd6, []int{73, 5} + return fileDescriptor_api_e552681b39a41c3e, []int{73, 5} } func (m *ExportStorage_Workload) XXX_Unmarshal(b []byte) error { return m.Unmarshal(b) @@ -3721,7 +3721,7 @@ func (m *WriteBatchRequest) Reset() { *m = WriteBatchRequest{} } func (m *WriteBatchRequest) String() string { return proto.CompactTextString(m) } func (*WriteBatchRequest) ProtoMessage() {} func (*WriteBatchRequest) Descriptor() ([]byte, []int) { - return fileDescriptor_api_0e495ec1ebba5dd6, []int{74} + return fileDescriptor_api_e552681b39a41c3e, []int{74} } func (m *WriteBatchRequest) XXX_Unmarshal(b []byte) error { return m.Unmarshal(b) @@ -3755,7 +3755,7 @@ func (m *WriteBatchResponse) Reset() { *m = WriteBatchResponse{} } func (m *WriteBatchResponse) String() string { return proto.CompactTextString(m) } func (*WriteBatchResponse) ProtoMessage() {} func (*WriteBatchResponse) Descriptor() ([]byte, []int) { - return fileDescriptor_api_0e495ec1ebba5dd6, []int{75} + return fileDescriptor_api_e552681b39a41c3e, []int{75} } func (m *WriteBatchResponse) XXX_Unmarshal(b []byte) error { return m.Unmarshal(b) @@ -3813,7 +3813,7 @@ func (m *ExportRequest) Reset() { *m = ExportRequest{} } func (m *ExportRequest) String() string { return proto.CompactTextString(m) } func (*ExportRequest) ProtoMessage() {} func (*ExportRequest) Descriptor() ([]byte, []int) { - return fileDescriptor_api_0e495ec1ebba5dd6, []int{76} + return fileDescriptor_api_e552681b39a41c3e, []int{76} } func (m *ExportRequest) XXX_Unmarshal(b []byte) error { return m.Unmarshal(b) @@ -3849,7 +3849,7 @@ func (m *BulkOpSummary) Reset() { *m = BulkOpSummary{} } func (m *BulkOpSummary) String() string { return proto.CompactTextString(m) } func (*BulkOpSummary) ProtoMessage() {} func (*BulkOpSummary) Descriptor() ([]byte, []int) { - return fileDescriptor_api_0e495ec1ebba5dd6, []int{77} + return fileDescriptor_api_e552681b39a41c3e, []int{77} } func (m *BulkOpSummary) XXX_Unmarshal(b []byte) error { return m.Unmarshal(b) @@ -3885,7 +3885,7 @@ func (m *ExportResponse) Reset() { *m = ExportResponse{} } func (m *ExportResponse) String() string { return proto.CompactTextString(m) } func (*ExportResponse) ProtoMessage() {} func (*ExportResponse) Descriptor() ([]byte, []int) { - return fileDescriptor_api_0e495ec1ebba5dd6, []int{78} + return fileDescriptor_api_e552681b39a41c3e, []int{78} } func (m *ExportResponse) XXX_Unmarshal(b []byte) error { return m.Unmarshal(b) @@ -3924,7 +3924,7 @@ func (m *ExportResponse_File) Reset() { *m = ExportResponse_File{} } func (m *ExportResponse_File) String() string { return proto.CompactTextString(m) } func (*ExportResponse_File) ProtoMessage() {} func (*ExportResponse_File) Descriptor() ([]byte, []int) { - return fileDescriptor_api_0e495ec1ebba5dd6, []int{78, 0} + return fileDescriptor_api_e552681b39a41c3e, []int{78, 0} } func (m *ExportResponse_File) XXX_Unmarshal(b []byte) error { return m.Unmarshal(b) @@ -3974,7 +3974,7 @@ func (m *ImportRequest) Reset() { *m = ImportRequest{} } func (m *ImportRequest) String() string { return proto.CompactTextString(m) } func (*ImportRequest) ProtoMessage() {} func (*ImportRequest) Descriptor() ([]byte, []int) { - return fileDescriptor_api_0e495ec1ebba5dd6, []int{79} + return fileDescriptor_api_e552681b39a41c3e, []int{79} } func (m *ImportRequest) XXX_Unmarshal(b []byte) error { return m.Unmarshal(b) @@ -4009,7 +4009,7 @@ func (m *ImportRequest_File) Reset() { *m = ImportRequest_File{} } func (m *ImportRequest_File) String() string { return proto.CompactTextString(m) } func (*ImportRequest_File) ProtoMessage() {} func (*ImportRequest_File) Descriptor() ([]byte, []int) { - return fileDescriptor_api_0e495ec1ebba5dd6, []int{79, 0} + return fileDescriptor_api_e552681b39a41c3e, []int{79, 0} } func (m *ImportRequest_File) XXX_Unmarshal(b []byte) error { return m.Unmarshal(b) @@ -4045,7 +4045,7 @@ func (m *ImportRequest_TableRekey) Reset() { *m = ImportRequest_TableRek func (m *ImportRequest_TableRekey) String() string { return proto.CompactTextString(m) } func (*ImportRequest_TableRekey) ProtoMessage() {} func (*ImportRequest_TableRekey) Descriptor() ([]byte, []int) { - return fileDescriptor_api_0e495ec1ebba5dd6, []int{79, 1} + return fileDescriptor_api_e552681b39a41c3e, []int{79, 1} } func (m *ImportRequest_TableRekey) XXX_Unmarshal(b []byte) error { return m.Unmarshal(b) @@ -4080,7 +4080,7 @@ func (m *ImportResponse) Reset() { *m = ImportResponse{} } func (m *ImportResponse) String() string { return proto.CompactTextString(m) } func (*ImportResponse) ProtoMessage() {} func (*ImportResponse) Descriptor() ([]byte, []int) { - return fileDescriptor_api_0e495ec1ebba5dd6, []int{80} + return fileDescriptor_api_e552681b39a41c3e, []int{80} } func (m *ImportResponse) XXX_Unmarshal(b []byte) error { return m.Unmarshal(b) @@ -4118,7 +4118,7 @@ func (m *AdminScatterRequest) Reset() { *m = AdminScatterRequest{} } func (m *AdminScatterRequest) String() string { return proto.CompactTextString(m) } func (*AdminScatterRequest) ProtoMessage() {} func (*AdminScatterRequest) Descriptor() ([]byte, []int) { - return fileDescriptor_api_0e495ec1ebba5dd6, []int{81} + return fileDescriptor_api_e552681b39a41c3e, []int{81} } func (m *AdminScatterRequest) XXX_Unmarshal(b []byte) error { return m.Unmarshal(b) @@ -4153,7 +4153,7 @@ func (m *AdminScatterResponse) Reset() { *m = AdminScatterResponse{} } func (m *AdminScatterResponse) String() string { return proto.CompactTextString(m) } func (*AdminScatterResponse) ProtoMessage() {} func (*AdminScatterResponse) Descriptor() ([]byte, []int) { - return fileDescriptor_api_0e495ec1ebba5dd6, []int{82} + return fileDescriptor_api_e552681b39a41c3e, []int{82} } func (m *AdminScatterResponse) XXX_Unmarshal(b []byte) error { return m.Unmarshal(b) @@ -4186,7 +4186,7 @@ func (m *AdminScatterResponse_Range) Reset() { *m = AdminScatterResponse func (m *AdminScatterResponse_Range) String() string { return proto.CompactTextString(m) } func (*AdminScatterResponse_Range) ProtoMessage() {} func (*AdminScatterResponse_Range) Descriptor() ([]byte, []int) { - return fileDescriptor_api_0e495ec1ebba5dd6, []int{82, 0} + return fileDescriptor_api_e552681b39a41c3e, []int{82, 0} } func (m *AdminScatterResponse_Range) XXX_Unmarshal(b []byte) error { return m.Unmarshal(b) @@ -4220,13 +4220,18 @@ type AddSSTableRequest struct { // shadow already existing key entries. This disallows any key slice overlap // regardless of the timestamps. DisallowShadowing bool `protobuf:"varint,3,opt,name=disallow_shadowing,json=disallowShadowing,proto3" json:"disallow_shadowing,omitempty"` + // MVCCStats, if set, is the MVCCStats for the contents of this SSTable and is + // used as-is during evaluation of the AddSSTable command to update the range + // MVCCStats, instead of computing the stats for the SSTable by iterating it. + // Including these stats can make the evaluation of AddSSTable much cheaper. + MVCCStats *enginepb.MVCCStats `protobuf:"bytes,4,opt,name=mvcc_stats,json=mvccStats,proto3" json:"mvcc_stats,omitempty"` } func (m *AddSSTableRequest) Reset() { *m = AddSSTableRequest{} } func (m *AddSSTableRequest) String() string { return proto.CompactTextString(m) } func (*AddSSTableRequest) ProtoMessage() {} func (*AddSSTableRequest) Descriptor() ([]byte, []int) { - return fileDescriptor_api_0e495ec1ebba5dd6, []int{83} + return fileDescriptor_api_e552681b39a41c3e, []int{83} } func (m *AddSSTableRequest) XXX_Unmarshal(b []byte) error { return m.Unmarshal(b) @@ -4260,7 +4265,7 @@ func (m *AddSSTableResponse) Reset() { *m = AddSSTableResponse{} } func (m *AddSSTableResponse) String() string { return proto.CompactTextString(m) } func (*AddSSTableResponse) ProtoMessage() {} func (*AddSSTableResponse) Descriptor() ([]byte, []int) { - return fileDescriptor_api_0e495ec1ebba5dd6, []int{84} + return fileDescriptor_api_e552681b39a41c3e, []int{84} } func (m *AddSSTableResponse) XXX_Unmarshal(b []byte) error { return m.Unmarshal(b) @@ -4304,7 +4309,7 @@ func (m *RefreshRequest) Reset() { *m = RefreshRequest{} } func (m *RefreshRequest) String() string { return proto.CompactTextString(m) } func (*RefreshRequest) ProtoMessage() {} func (*RefreshRequest) Descriptor() ([]byte, []int) { - return fileDescriptor_api_0e495ec1ebba5dd6, []int{85} + return fileDescriptor_api_e552681b39a41c3e, []int{85} } func (m *RefreshRequest) XXX_Unmarshal(b []byte) error { return m.Unmarshal(b) @@ -4338,7 +4343,7 @@ func (m *RefreshResponse) Reset() { *m = RefreshResponse{} } func (m *RefreshResponse) String() string { return proto.CompactTextString(m) } func (*RefreshResponse) ProtoMessage() {} func (*RefreshResponse) Descriptor() ([]byte, []int) { - return fileDescriptor_api_0e495ec1ebba5dd6, []int{86} + return fileDescriptor_api_e552681b39a41c3e, []int{86} } func (m *RefreshResponse) XXX_Unmarshal(b []byte) error { return m.Unmarshal(b) @@ -4378,7 +4383,7 @@ func (m *RefreshRangeRequest) Reset() { *m = RefreshRangeRequest{} } func (m *RefreshRangeRequest) String() string { return proto.CompactTextString(m) } func (*RefreshRangeRequest) ProtoMessage() {} func (*RefreshRangeRequest) Descriptor() ([]byte, []int) { - return fileDescriptor_api_0e495ec1ebba5dd6, []int{87} + return fileDescriptor_api_e552681b39a41c3e, []int{87} } func (m *RefreshRangeRequest) XXX_Unmarshal(b []byte) error { return m.Unmarshal(b) @@ -4412,7 +4417,7 @@ func (m *RefreshRangeResponse) Reset() { *m = RefreshRangeResponse{} } func (m *RefreshRangeResponse) String() string { return proto.CompactTextString(m) } func (*RefreshRangeResponse) ProtoMessage() {} func (*RefreshRangeResponse) Descriptor() ([]byte, []int) { - return fileDescriptor_api_0e495ec1ebba5dd6, []int{88} + return fileDescriptor_api_e552681b39a41c3e, []int{88} } func (m *RefreshRangeResponse) XXX_Unmarshal(b []byte) error { return m.Unmarshal(b) @@ -4464,7 +4469,7 @@ func (m *SubsumeRequest) Reset() { *m = SubsumeRequest{} } func (m *SubsumeRequest) String() string { return proto.CompactTextString(m) } func (*SubsumeRequest) ProtoMessage() {} func (*SubsumeRequest) Descriptor() ([]byte, []int) { - return fileDescriptor_api_0e495ec1ebba5dd6, []int{89} + return fileDescriptor_api_e552681b39a41c3e, []int{89} } func (m *SubsumeRequest) XXX_Unmarshal(b []byte) error { return m.Unmarshal(b) @@ -4509,7 +4514,7 @@ func (m *SubsumeResponse) Reset() { *m = SubsumeResponse{} } func (m *SubsumeResponse) String() string { return proto.CompactTextString(m) } func (*SubsumeResponse) ProtoMessage() {} func (*SubsumeResponse) Descriptor() ([]byte, []int) { - return fileDescriptor_api_0e495ec1ebba5dd6, []int{90} + return fileDescriptor_api_e552681b39a41c3e, []int{90} } func (m *SubsumeResponse) XXX_Unmarshal(b []byte) error { return m.Unmarshal(b) @@ -4544,7 +4549,7 @@ func (m *RangeStatsRequest) Reset() { *m = RangeStatsRequest{} } func (m *RangeStatsRequest) String() string { return proto.CompactTextString(m) } func (*RangeStatsRequest) ProtoMessage() {} func (*RangeStatsRequest) Descriptor() ([]byte, []int) { - return fileDescriptor_api_0e495ec1ebba5dd6, []int{91} + return fileDescriptor_api_e552681b39a41c3e, []int{91} } func (m *RangeStatsRequest) XXX_Unmarshal(b []byte) error { return m.Unmarshal(b) @@ -4583,7 +4588,7 @@ func (m *RangeStatsResponse) Reset() { *m = RangeStatsResponse{} } func (m *RangeStatsResponse) String() string { return proto.CompactTextString(m) } func (*RangeStatsResponse) ProtoMessage() {} func (*RangeStatsResponse) Descriptor() ([]byte, []int) { - return fileDescriptor_api_0e495ec1ebba5dd6, []int{92} + return fileDescriptor_api_e552681b39a41c3e, []int{92} } func (m *RangeStatsResponse) XXX_Unmarshal(b []byte) error { return m.Unmarshal(b) @@ -4666,7 +4671,7 @@ func (m *RequestUnion) Reset() { *m = RequestUnion{} } func (m *RequestUnion) String() string { return proto.CompactTextString(m) } func (*RequestUnion) ProtoMessage() {} func (*RequestUnion) Descriptor() ([]byte, []int) { - return fileDescriptor_api_0e495ec1ebba5dd6, []int{93} + return fileDescriptor_api_e552681b39a41c3e, []int{93} } func (m *RequestUnion) XXX_Unmarshal(b []byte) error { return m.Unmarshal(b) @@ -6116,7 +6121,7 @@ func (m *ResponseUnion) Reset() { *m = ResponseUnion{} } func (m *ResponseUnion) String() string { return proto.CompactTextString(m) } func (*ResponseUnion) ProtoMessage() {} func (*ResponseUnion) Descriptor() ([]byte, []int) { - return fileDescriptor_api_0e495ec1ebba5dd6, []int{94} + return fileDescriptor_api_e552681b39a41c3e, []int{94} } func (m *ResponseUnion) XXX_Unmarshal(b []byte) error { return m.Unmarshal(b) @@ -7560,7 +7565,7 @@ func (m *Header) Reset() { *m = Header{} } func (m *Header) String() string { return proto.CompactTextString(m) } func (*Header) ProtoMessage() {} func (*Header) Descriptor() ([]byte, []int) { - return fileDescriptor_api_0e495ec1ebba5dd6, []int{95} + return fileDescriptor_api_e552681b39a41c3e, []int{95} } func (m *Header) XXX_Unmarshal(b []byte) error { return m.Unmarshal(b) @@ -7596,7 +7601,7 @@ type BatchRequest struct { func (m *BatchRequest) Reset() { *m = BatchRequest{} } func (*BatchRequest) ProtoMessage() {} func (*BatchRequest) Descriptor() ([]byte, []int) { - return fileDescriptor_api_0e495ec1ebba5dd6, []int{96} + return fileDescriptor_api_e552681b39a41c3e, []int{96} } func (m *BatchRequest) XXX_Unmarshal(b []byte) error { return m.Unmarshal(b) @@ -7633,7 +7638,7 @@ type BatchResponse struct { func (m *BatchResponse) Reset() { *m = BatchResponse{} } func (*BatchResponse) ProtoMessage() {} func (*BatchResponse) Descriptor() ([]byte, []int) { - return fileDescriptor_api_0e495ec1ebba5dd6, []int{97} + return fileDescriptor_api_e552681b39a41c3e, []int{97} } func (m *BatchResponse) XXX_Unmarshal(b []byte) error { return m.Unmarshal(b) @@ -7692,7 +7697,7 @@ func (m *BatchResponse_Header) Reset() { *m = BatchResponse_Header{} } func (m *BatchResponse_Header) String() string { return proto.CompactTextString(m) } func (*BatchResponse_Header) ProtoMessage() {} func (*BatchResponse_Header) Descriptor() ([]byte, []int) { - return fileDescriptor_api_0e495ec1ebba5dd6, []int{97, 0} + return fileDescriptor_api_e552681b39a41c3e, []int{97, 0} } func (m *BatchResponse_Header) XXX_Unmarshal(b []byte) error { return m.Unmarshal(b) @@ -7728,7 +7733,7 @@ func (m *RangeFeedRequest) Reset() { *m = RangeFeedRequest{} } func (m *RangeFeedRequest) String() string { return proto.CompactTextString(m) } func (*RangeFeedRequest) ProtoMessage() {} func (*RangeFeedRequest) Descriptor() ([]byte, []int) { - return fileDescriptor_api_0e495ec1ebba5dd6, []int{98} + return fileDescriptor_api_e552681b39a41c3e, []int{98} } func (m *RangeFeedRequest) XXX_Unmarshal(b []byte) error { return m.Unmarshal(b) @@ -7764,7 +7769,7 @@ func (m *RangeFeedValue) Reset() { *m = RangeFeedValue{} } func (m *RangeFeedValue) String() string { return proto.CompactTextString(m) } func (*RangeFeedValue) ProtoMessage() {} func (*RangeFeedValue) Descriptor() ([]byte, []int) { - return fileDescriptor_api_0e495ec1ebba5dd6, []int{99} + return fileDescriptor_api_e552681b39a41c3e, []int{99} } func (m *RangeFeedValue) XXX_Unmarshal(b []byte) error { return m.Unmarshal(b) @@ -7805,7 +7810,7 @@ func (m *RangeFeedCheckpoint) Reset() { *m = RangeFeedCheckpoint{} } func (m *RangeFeedCheckpoint) String() string { return proto.CompactTextString(m) } func (*RangeFeedCheckpoint) ProtoMessage() {} func (*RangeFeedCheckpoint) Descriptor() ([]byte, []int) { - return fileDescriptor_api_0e495ec1ebba5dd6, []int{100} + return fileDescriptor_api_e552681b39a41c3e, []int{100} } func (m *RangeFeedCheckpoint) XXX_Unmarshal(b []byte) error { return m.Unmarshal(b) @@ -7842,7 +7847,7 @@ func (m *RangeFeedError) Reset() { *m = RangeFeedError{} } func (m *RangeFeedError) String() string { return proto.CompactTextString(m) } func (*RangeFeedError) ProtoMessage() {} func (*RangeFeedError) Descriptor() ([]byte, []int) { - return fileDescriptor_api_0e495ec1ebba5dd6, []int{101} + return fileDescriptor_api_e552681b39a41c3e, []int{101} } func (m *RangeFeedError) XXX_Unmarshal(b []byte) error { return m.Unmarshal(b) @@ -7879,7 +7884,7 @@ func (m *RangeFeedEvent) Reset() { *m = RangeFeedEvent{} } func (m *RangeFeedEvent) String() string { return proto.CompactTextString(m) } func (*RangeFeedEvent) ProtoMessage() {} func (*RangeFeedEvent) Descriptor() ([]byte, []int) { - return fileDescriptor_api_0e495ec1ebba5dd6, []int{102} + return fileDescriptor_api_e552681b39a41c3e, []int{102} } func (m *RangeFeedEvent) XXX_Unmarshal(b []byte) error { return m.Unmarshal(b) @@ -9675,6 +9680,9 @@ func (this *AddSSTableRequest) Equal(that interface{}) bool { if this.DisallowShadowing != that1.DisallowShadowing { return false } + if !this.MVCCStats.Equal(that1.MVCCStats) { + return false + } return true } func (this *RefreshRequest) Equal(that interface{}) bool { @@ -13687,6 +13695,16 @@ func (m *AddSSTableRequest) MarshalTo(dAtA []byte) (int, error) { } i++ } + if m.MVCCStats != nil { + dAtA[i] = 0x22 + i++ + i = encodeVarintApi(dAtA, i, uint64(m.MVCCStats.Size())) + n137, err := m.MVCCStats.MarshalTo(dAtA[i:]) + if err != nil { + return 0, err + } + i += n137 + } return i, nil } @@ -13708,11 +13726,11 @@ func (m *AddSSTableResponse) MarshalTo(dAtA []byte) (int, error) { dAtA[i] = 0xa i++ i = encodeVarintApi(dAtA, i, uint64(m.ResponseHeader.Size())) - n137, err := m.ResponseHeader.MarshalTo(dAtA[i:]) + n138, err := m.ResponseHeader.MarshalTo(dAtA[i:]) if err != nil { return 0, err } - i += n137 + i += n138 return i, nil } @@ -13734,11 +13752,11 @@ func (m *RefreshRequest) MarshalTo(dAtA []byte) (int, error) { dAtA[i] = 0xa i++ i = encodeVarintApi(dAtA, i, uint64(m.RequestHeader.Size())) - n138, err := m.RequestHeader.MarshalTo(dAtA[i:]) + n139, err := m.RequestHeader.MarshalTo(dAtA[i:]) if err != nil { return 0, err } - i += n138 + i += n139 if m.Write { dAtA[i] = 0x10 i++ @@ -13770,11 +13788,11 @@ func (m *RefreshResponse) MarshalTo(dAtA []byte) (int, error) { dAtA[i] = 0xa i++ i = encodeVarintApi(dAtA, i, uint64(m.ResponseHeader.Size())) - n139, err := m.ResponseHeader.MarshalTo(dAtA[i:]) + n140, err := m.ResponseHeader.MarshalTo(dAtA[i:]) if err != nil { return 0, err } - i += n139 + i += n140 return i, nil } @@ -13796,11 +13814,11 @@ func (m *RefreshRangeRequest) MarshalTo(dAtA []byte) (int, error) { dAtA[i] = 0xa i++ i = encodeVarintApi(dAtA, i, uint64(m.RequestHeader.Size())) - n140, err := m.RequestHeader.MarshalTo(dAtA[i:]) + n141, err := m.RequestHeader.MarshalTo(dAtA[i:]) if err != nil { return 0, err } - i += n140 + i += n141 if m.Write { dAtA[i] = 0x10 i++ @@ -13832,11 +13850,11 @@ func (m *RefreshRangeResponse) MarshalTo(dAtA []byte) (int, error) { dAtA[i] = 0xa i++ i = encodeVarintApi(dAtA, i, uint64(m.ResponseHeader.Size())) - n141, err := m.ResponseHeader.MarshalTo(dAtA[i:]) + n142, err := m.ResponseHeader.MarshalTo(dAtA[i:]) if err != nil { return 0, err } - i += n141 + i += n142 return i, nil } @@ -13858,28 +13876,28 @@ func (m *SubsumeRequest) MarshalTo(dAtA []byte) (int, error) { dAtA[i] = 0xa i++ i = encodeVarintApi(dAtA, i, uint64(m.RequestHeader.Size())) - n142, err := m.RequestHeader.MarshalTo(dAtA[i:]) + n143, err := m.RequestHeader.MarshalTo(dAtA[i:]) if err != nil { return 0, err } - i += n142 + i += n143 dAtA[i] = 0x12 i++ i = encodeVarintApi(dAtA, i, uint64(m.LeftDesc.Size())) - n143, err := m.LeftDesc.MarshalTo(dAtA[i:]) + n144, err := m.LeftDesc.MarshalTo(dAtA[i:]) if err != nil { return 0, err } - i += n143 + i += n144 if m.RightDesc != nil { dAtA[i] = 0x1a i++ i = encodeVarintApi(dAtA, i, uint64(m.RightDesc.Size())) - n144, err := m.RightDesc.MarshalTo(dAtA[i:]) + n145, err := m.RightDesc.MarshalTo(dAtA[i:]) if err != nil { return 0, err } - i += n144 + i += n145 } return i, nil } @@ -13902,19 +13920,19 @@ func (m *SubsumeResponse) MarshalTo(dAtA []byte) (int, error) { dAtA[i] = 0xa i++ i = encodeVarintApi(dAtA, i, uint64(m.ResponseHeader.Size())) - n145, err := m.ResponseHeader.MarshalTo(dAtA[i:]) + n146, err := m.ResponseHeader.MarshalTo(dAtA[i:]) if err != nil { return 0, err } - i += n145 + i += n146 dAtA[i] = 0x1a i++ i = encodeVarintApi(dAtA, i, uint64(m.MVCCStats.Size())) - n146, err := m.MVCCStats.MarshalTo(dAtA[i:]) + n147, err := m.MVCCStats.MarshalTo(dAtA[i:]) if err != nil { return 0, err } - i += n146 + i += n147 if m.LeaseAppliedIndex != 0 { dAtA[i] = 0x20 i++ @@ -13923,11 +13941,11 @@ func (m *SubsumeResponse) MarshalTo(dAtA []byte) (int, error) { dAtA[i] = 0x2a i++ i = encodeVarintApi(dAtA, i, uint64(m.FreezeStart.Size())) - n147, err := m.FreezeStart.MarshalTo(dAtA[i:]) + n148, err := m.FreezeStart.MarshalTo(dAtA[i:]) if err != nil { return 0, err } - i += n147 + i += n148 return i, nil } @@ -13949,11 +13967,11 @@ func (m *RangeStatsRequest) MarshalTo(dAtA []byte) (int, error) { dAtA[i] = 0xa i++ i = encodeVarintApi(dAtA, i, uint64(m.RequestHeader.Size())) - n148, err := m.RequestHeader.MarshalTo(dAtA[i:]) + n149, err := m.RequestHeader.MarshalTo(dAtA[i:]) if err != nil { return 0, err } - i += n148 + i += n149 return i, nil } @@ -13975,19 +13993,19 @@ func (m *RangeStatsResponse) MarshalTo(dAtA []byte) (int, error) { dAtA[i] = 0xa i++ i = encodeVarintApi(dAtA, i, uint64(m.ResponseHeader.Size())) - n149, err := m.ResponseHeader.MarshalTo(dAtA[i:]) + n150, err := m.ResponseHeader.MarshalTo(dAtA[i:]) if err != nil { return 0, err } - i += n149 + i += n150 dAtA[i] = 0x12 i++ i = encodeVarintApi(dAtA, i, uint64(m.MVCCStats.Size())) - n150, err := m.MVCCStats.MarshalTo(dAtA[i:]) + n151, err := m.MVCCStats.MarshalTo(dAtA[i:]) if err != nil { return 0, err } - i += n150 + i += n151 if m.QueriesPerSecond != 0 { dAtA[i] = 0x19 i++ @@ -14013,11 +14031,11 @@ func (m *RequestUnion) MarshalTo(dAtA []byte) (int, error) { var l int _ = l if m.Value != nil { - nn151, err := m.Value.MarshalTo(dAtA[i:]) + nn152, err := m.Value.MarshalTo(dAtA[i:]) if err != nil { return 0, err } - i += nn151 + i += nn152 } return i, nil } @@ -14028,11 +14046,11 @@ func (m *RequestUnion_Get) MarshalTo(dAtA []byte) (int, error) { dAtA[i] = 0xa i++ i = encodeVarintApi(dAtA, i, uint64(m.Get.Size())) - n152, err := m.Get.MarshalTo(dAtA[i:]) + n153, err := m.Get.MarshalTo(dAtA[i:]) if err != nil { return 0, err } - i += n152 + i += n153 } return i, nil } @@ -14042,11 +14060,11 @@ func (m *RequestUnion_Put) MarshalTo(dAtA []byte) (int, error) { dAtA[i] = 0x12 i++ i = encodeVarintApi(dAtA, i, uint64(m.Put.Size())) - n153, err := m.Put.MarshalTo(dAtA[i:]) + n154, err := m.Put.MarshalTo(dAtA[i:]) if err != nil { return 0, err } - i += n153 + i += n154 } return i, nil } @@ -14056,11 +14074,11 @@ func (m *RequestUnion_ConditionalPut) MarshalTo(dAtA []byte) (int, error) { dAtA[i] = 0x1a i++ i = encodeVarintApi(dAtA, i, uint64(m.ConditionalPut.Size())) - n154, err := m.ConditionalPut.MarshalTo(dAtA[i:]) + n155, err := m.ConditionalPut.MarshalTo(dAtA[i:]) if err != nil { return 0, err } - i += n154 + i += n155 } return i, nil } @@ -14070,11 +14088,11 @@ func (m *RequestUnion_Increment) MarshalTo(dAtA []byte) (int, error) { dAtA[i] = 0x22 i++ i = encodeVarintApi(dAtA, i, uint64(m.Increment.Size())) - n155, err := m.Increment.MarshalTo(dAtA[i:]) + n156, err := m.Increment.MarshalTo(dAtA[i:]) if err != nil { return 0, err } - i += n155 + i += n156 } return i, nil } @@ -14084,11 +14102,11 @@ func (m *RequestUnion_Delete) MarshalTo(dAtA []byte) (int, error) { dAtA[i] = 0x2a i++ i = encodeVarintApi(dAtA, i, uint64(m.Delete.Size())) - n156, err := m.Delete.MarshalTo(dAtA[i:]) + n157, err := m.Delete.MarshalTo(dAtA[i:]) if err != nil { return 0, err } - i += n156 + i += n157 } return i, nil } @@ -14098,11 +14116,11 @@ func (m *RequestUnion_DeleteRange) MarshalTo(dAtA []byte) (int, error) { dAtA[i] = 0x32 i++ i = encodeVarintApi(dAtA, i, uint64(m.DeleteRange.Size())) - n157, err := m.DeleteRange.MarshalTo(dAtA[i:]) + n158, err := m.DeleteRange.MarshalTo(dAtA[i:]) if err != nil { return 0, err } - i += n157 + i += n158 } return i, nil } @@ -14112,11 +14130,11 @@ func (m *RequestUnion_Scan) MarshalTo(dAtA []byte) (int, error) { dAtA[i] = 0x3a i++ i = encodeVarintApi(dAtA, i, uint64(m.Scan.Size())) - n158, err := m.Scan.MarshalTo(dAtA[i:]) + n159, err := m.Scan.MarshalTo(dAtA[i:]) if err != nil { return 0, err } - i += n158 + i += n159 } return i, nil } @@ -14126,11 +14144,11 @@ func (m *RequestUnion_BeginTransaction) MarshalTo(dAtA []byte) (int, error) { dAtA[i] = 0x42 i++ i = encodeVarintApi(dAtA, i, uint64(m.BeginTransaction.Size())) - n159, err := m.BeginTransaction.MarshalTo(dAtA[i:]) + n160, err := m.BeginTransaction.MarshalTo(dAtA[i:]) if err != nil { return 0, err } - i += n159 + i += n160 } return i, nil } @@ -14140,11 +14158,11 @@ func (m *RequestUnion_EndTransaction) MarshalTo(dAtA []byte) (int, error) { dAtA[i] = 0x4a i++ i = encodeVarintApi(dAtA, i, uint64(m.EndTransaction.Size())) - n160, err := m.EndTransaction.MarshalTo(dAtA[i:]) + n161, err := m.EndTransaction.MarshalTo(dAtA[i:]) if err != nil { return 0, err } - i += n160 + i += n161 } return i, nil } @@ -14154,11 +14172,11 @@ func (m *RequestUnion_AdminSplit) MarshalTo(dAtA []byte) (int, error) { dAtA[i] = 0x52 i++ i = encodeVarintApi(dAtA, i, uint64(m.AdminSplit.Size())) - n161, err := m.AdminSplit.MarshalTo(dAtA[i:]) + n162, err := m.AdminSplit.MarshalTo(dAtA[i:]) if err != nil { return 0, err } - i += n161 + i += n162 } return i, nil } @@ -14168,11 +14186,11 @@ func (m *RequestUnion_AdminMerge) MarshalTo(dAtA []byte) (int, error) { dAtA[i] = 0x5a i++ i = encodeVarintApi(dAtA, i, uint64(m.AdminMerge.Size())) - n162, err := m.AdminMerge.MarshalTo(dAtA[i:]) + n163, err := m.AdminMerge.MarshalTo(dAtA[i:]) if err != nil { return 0, err } - i += n162 + i += n163 } return i, nil } @@ -14182,11 +14200,11 @@ func (m *RequestUnion_HeartbeatTxn) MarshalTo(dAtA []byte) (int, error) { dAtA[i] = 0x62 i++ i = encodeVarintApi(dAtA, i, uint64(m.HeartbeatTxn.Size())) - n163, err := m.HeartbeatTxn.MarshalTo(dAtA[i:]) + n164, err := m.HeartbeatTxn.MarshalTo(dAtA[i:]) if err != nil { return 0, err } - i += n163 + i += n164 } return i, nil } @@ -14196,11 +14214,11 @@ func (m *RequestUnion_Gc) MarshalTo(dAtA []byte) (int, error) { dAtA[i] = 0x6a i++ i = encodeVarintApi(dAtA, i, uint64(m.Gc.Size())) - n164, err := m.Gc.MarshalTo(dAtA[i:]) + n165, err := m.Gc.MarshalTo(dAtA[i:]) if err != nil { return 0, err } - i += n164 + i += n165 } return i, nil } @@ -14210,11 +14228,11 @@ func (m *RequestUnion_PushTxn) MarshalTo(dAtA []byte) (int, error) { dAtA[i] = 0x72 i++ i = encodeVarintApi(dAtA, i, uint64(m.PushTxn.Size())) - n165, err := m.PushTxn.MarshalTo(dAtA[i:]) + n166, err := m.PushTxn.MarshalTo(dAtA[i:]) if err != nil { return 0, err } - i += n165 + i += n166 } return i, nil } @@ -14226,11 +14244,11 @@ func (m *RequestUnion_ResolveIntent) MarshalTo(dAtA []byte) (int, error) { dAtA[i] = 0x1 i++ i = encodeVarintApi(dAtA, i, uint64(m.ResolveIntent.Size())) - n166, err := m.ResolveIntent.MarshalTo(dAtA[i:]) + n167, err := m.ResolveIntent.MarshalTo(dAtA[i:]) if err != nil { return 0, err } - i += n166 + i += n167 } return i, nil } @@ -14242,11 +14260,11 @@ func (m *RequestUnion_ResolveIntentRange) MarshalTo(dAtA []byte) (int, error) { dAtA[i] = 0x1 i++ i = encodeVarintApi(dAtA, i, uint64(m.ResolveIntentRange.Size())) - n167, err := m.ResolveIntentRange.MarshalTo(dAtA[i:]) + n168, err := m.ResolveIntentRange.MarshalTo(dAtA[i:]) if err != nil { return 0, err } - i += n167 + i += n168 } return i, nil } @@ -14258,11 +14276,11 @@ func (m *RequestUnion_Merge) MarshalTo(dAtA []byte) (int, error) { dAtA[i] = 0x1 i++ i = encodeVarintApi(dAtA, i, uint64(m.Merge.Size())) - n168, err := m.Merge.MarshalTo(dAtA[i:]) + n169, err := m.Merge.MarshalTo(dAtA[i:]) if err != nil { return 0, err } - i += n168 + i += n169 } return i, nil } @@ -14274,11 +14292,11 @@ func (m *RequestUnion_TruncateLog) MarshalTo(dAtA []byte) (int, error) { dAtA[i] = 0x1 i++ i = encodeVarintApi(dAtA, i, uint64(m.TruncateLog.Size())) - n169, err := m.TruncateLog.MarshalTo(dAtA[i:]) + n170, err := m.TruncateLog.MarshalTo(dAtA[i:]) if err != nil { return 0, err } - i += n169 + i += n170 } return i, nil } @@ -14290,11 +14308,11 @@ func (m *RequestUnion_RequestLease) MarshalTo(dAtA []byte) (int, error) { dAtA[i] = 0x1 i++ i = encodeVarintApi(dAtA, i, uint64(m.RequestLease.Size())) - n170, err := m.RequestLease.MarshalTo(dAtA[i:]) + n171, err := m.RequestLease.MarshalTo(dAtA[i:]) if err != nil { return 0, err } - i += n170 + i += n171 } return i, nil } @@ -14306,11 +14324,11 @@ func (m *RequestUnion_ReverseScan) MarshalTo(dAtA []byte) (int, error) { dAtA[i] = 0x1 i++ i = encodeVarintApi(dAtA, i, uint64(m.ReverseScan.Size())) - n171, err := m.ReverseScan.MarshalTo(dAtA[i:]) + n172, err := m.ReverseScan.MarshalTo(dAtA[i:]) if err != nil { return 0, err } - i += n171 + i += n172 } return i, nil } @@ -14322,11 +14340,11 @@ func (m *RequestUnion_ComputeChecksum) MarshalTo(dAtA []byte) (int, error) { dAtA[i] = 0x1 i++ i = encodeVarintApi(dAtA, i, uint64(m.ComputeChecksum.Size())) - n172, err := m.ComputeChecksum.MarshalTo(dAtA[i:]) + n173, err := m.ComputeChecksum.MarshalTo(dAtA[i:]) if err != nil { return 0, err } - i += n172 + i += n173 } return i, nil } @@ -14338,11 +14356,11 @@ func (m *RequestUnion_CheckConsistency) MarshalTo(dAtA []byte) (int, error) { dAtA[i] = 0x1 i++ i = encodeVarintApi(dAtA, i, uint64(m.CheckConsistency.Size())) - n173, err := m.CheckConsistency.MarshalTo(dAtA[i:]) + n174, err := m.CheckConsistency.MarshalTo(dAtA[i:]) if err != nil { return 0, err } - i += n173 + i += n174 } return i, nil } @@ -14354,11 +14372,11 @@ func (m *RequestUnion_InitPut) MarshalTo(dAtA []byte) (int, error) { dAtA[i] = 0x1 i++ i = encodeVarintApi(dAtA, i, uint64(m.InitPut.Size())) - n174, err := m.InitPut.MarshalTo(dAtA[i:]) + n175, err := m.InitPut.MarshalTo(dAtA[i:]) if err != nil { return 0, err } - i += n174 + i += n175 } return i, nil } @@ -14370,11 +14388,11 @@ func (m *RequestUnion_TransferLease) MarshalTo(dAtA []byte) (int, error) { dAtA[i] = 0x1 i++ i = encodeVarintApi(dAtA, i, uint64(m.TransferLease.Size())) - n175, err := m.TransferLease.MarshalTo(dAtA[i:]) + n176, err := m.TransferLease.MarshalTo(dAtA[i:]) if err != nil { return 0, err } - i += n175 + i += n176 } return i, nil } @@ -14386,11 +14404,11 @@ func (m *RequestUnion_AdminTransferLease) MarshalTo(dAtA []byte) (int, error) { dAtA[i] = 0x1 i++ i = encodeVarintApi(dAtA, i, uint64(m.AdminTransferLease.Size())) - n176, err := m.AdminTransferLease.MarshalTo(dAtA[i:]) + n177, err := m.AdminTransferLease.MarshalTo(dAtA[i:]) if err != nil { return 0, err } - i += n176 + i += n177 } return i, nil } @@ -14402,11 +14420,11 @@ func (m *RequestUnion_LeaseInfo) MarshalTo(dAtA []byte) (int, error) { dAtA[i] = 0x1 i++ i = encodeVarintApi(dAtA, i, uint64(m.LeaseInfo.Size())) - n177, err := m.LeaseInfo.MarshalTo(dAtA[i:]) + n178, err := m.LeaseInfo.MarshalTo(dAtA[i:]) if err != nil { return 0, err } - i += n177 + i += n178 } return i, nil } @@ -14418,11 +14436,11 @@ func (m *RequestUnion_WriteBatch) MarshalTo(dAtA []byte) (int, error) { dAtA[i] = 0x1 i++ i = encodeVarintApi(dAtA, i, uint64(m.WriteBatch.Size())) - n178, err := m.WriteBatch.MarshalTo(dAtA[i:]) + n179, err := m.WriteBatch.MarshalTo(dAtA[i:]) if err != nil { return 0, err } - i += n178 + i += n179 } return i, nil } @@ -14434,11 +14452,11 @@ func (m *RequestUnion_Export) MarshalTo(dAtA []byte) (int, error) { dAtA[i] = 0x2 i++ i = encodeVarintApi(dAtA, i, uint64(m.Export.Size())) - n179, err := m.Export.MarshalTo(dAtA[i:]) + n180, err := m.Export.MarshalTo(dAtA[i:]) if err != nil { return 0, err } - i += n179 + i += n180 } return i, nil } @@ -14450,11 +14468,11 @@ func (m *RequestUnion_QueryTxn) MarshalTo(dAtA []byte) (int, error) { dAtA[i] = 0x2 i++ i = encodeVarintApi(dAtA, i, uint64(m.QueryTxn.Size())) - n180, err := m.QueryTxn.MarshalTo(dAtA[i:]) + n181, err := m.QueryTxn.MarshalTo(dAtA[i:]) if err != nil { return 0, err } - i += n180 + i += n181 } return i, nil } @@ -14466,11 +14484,11 @@ func (m *RequestUnion_Import) MarshalTo(dAtA []byte) (int, error) { dAtA[i] = 0x2 i++ i = encodeVarintApi(dAtA, i, uint64(m.Import.Size())) - n181, err := m.Import.MarshalTo(dAtA[i:]) + n182, err := m.Import.MarshalTo(dAtA[i:]) if err != nil { return 0, err } - i += n181 + i += n182 } return i, nil } @@ -14482,11 +14500,11 @@ func (m *RequestUnion_AdminChangeReplicas) MarshalTo(dAtA []byte) (int, error) { dAtA[i] = 0x2 i++ i = encodeVarintApi(dAtA, i, uint64(m.AdminChangeReplicas.Size())) - n182, err := m.AdminChangeReplicas.MarshalTo(dAtA[i:]) + n183, err := m.AdminChangeReplicas.MarshalTo(dAtA[i:]) if err != nil { return 0, err } - i += n182 + i += n183 } return i, nil } @@ -14498,11 +14516,11 @@ func (m *RequestUnion_AdminScatter) MarshalTo(dAtA []byte) (int, error) { dAtA[i] = 0x2 i++ i = encodeVarintApi(dAtA, i, uint64(m.AdminScatter.Size())) - n183, err := m.AdminScatter.MarshalTo(dAtA[i:]) + n184, err := m.AdminScatter.MarshalTo(dAtA[i:]) if err != nil { return 0, err } - i += n183 + i += n184 } return i, nil } @@ -14514,11 +14532,11 @@ func (m *RequestUnion_AddSstable) MarshalTo(dAtA []byte) (int, error) { dAtA[i] = 0x2 i++ i = encodeVarintApi(dAtA, i, uint64(m.AddSstable.Size())) - n184, err := m.AddSstable.MarshalTo(dAtA[i:]) + n185, err := m.AddSstable.MarshalTo(dAtA[i:]) if err != nil { return 0, err } - i += n184 + i += n185 } return i, nil } @@ -14530,11 +14548,11 @@ func (m *RequestUnion_ClearRange) MarshalTo(dAtA []byte) (int, error) { dAtA[i] = 0x2 i++ i = encodeVarintApi(dAtA, i, uint64(m.ClearRange.Size())) - n185, err := m.ClearRange.MarshalTo(dAtA[i:]) + n186, err := m.ClearRange.MarshalTo(dAtA[i:]) if err != nil { return 0, err } - i += n185 + i += n186 } return i, nil } @@ -14546,11 +14564,11 @@ func (m *RequestUnion_RecomputeStats) MarshalTo(dAtA []byte) (int, error) { dAtA[i] = 0x2 i++ i = encodeVarintApi(dAtA, i, uint64(m.RecomputeStats.Size())) - n186, err := m.RecomputeStats.MarshalTo(dAtA[i:]) + n187, err := m.RecomputeStats.MarshalTo(dAtA[i:]) if err != nil { return 0, err } - i += n186 + i += n187 } return i, nil } @@ -14562,11 +14580,11 @@ func (m *RequestUnion_Refresh) MarshalTo(dAtA []byte) (int, error) { dAtA[i] = 0x2 i++ i = encodeVarintApi(dAtA, i, uint64(m.Refresh.Size())) - n187, err := m.Refresh.MarshalTo(dAtA[i:]) + n188, err := m.Refresh.MarshalTo(dAtA[i:]) if err != nil { return 0, err } - i += n187 + i += n188 } return i, nil } @@ -14578,11 +14596,11 @@ func (m *RequestUnion_RefreshRange) MarshalTo(dAtA []byte) (int, error) { dAtA[i] = 0x2 i++ i = encodeVarintApi(dAtA, i, uint64(m.RefreshRange.Size())) - n188, err := m.RefreshRange.MarshalTo(dAtA[i:]) + n189, err := m.RefreshRange.MarshalTo(dAtA[i:]) if err != nil { return 0, err } - i += n188 + i += n189 } return i, nil } @@ -14594,11 +14612,11 @@ func (m *RequestUnion_QueryIntent) MarshalTo(dAtA []byte) (int, error) { dAtA[i] = 0x2 i++ i = encodeVarintApi(dAtA, i, uint64(m.QueryIntent.Size())) - n189, err := m.QueryIntent.MarshalTo(dAtA[i:]) + n190, err := m.QueryIntent.MarshalTo(dAtA[i:]) if err != nil { return 0, err } - i += n189 + i += n190 } return i, nil } @@ -14610,11 +14628,11 @@ func (m *RequestUnion_Subsume) MarshalTo(dAtA []byte) (int, error) { dAtA[i] = 0x2 i++ i = encodeVarintApi(dAtA, i, uint64(m.Subsume.Size())) - n190, err := m.Subsume.MarshalTo(dAtA[i:]) + n191, err := m.Subsume.MarshalTo(dAtA[i:]) if err != nil { return 0, err } - i += n190 + i += n191 } return i, nil } @@ -14626,11 +14644,11 @@ func (m *RequestUnion_RangeStats) MarshalTo(dAtA []byte) (int, error) { dAtA[i] = 0x2 i++ i = encodeVarintApi(dAtA, i, uint64(m.RangeStats.Size())) - n191, err := m.RangeStats.MarshalTo(dAtA[i:]) + n192, err := m.RangeStats.MarshalTo(dAtA[i:]) if err != nil { return 0, err } - i += n191 + i += n192 } return i, nil } @@ -14642,11 +14660,11 @@ func (m *RequestUnion_AdminRelocateRange) MarshalTo(dAtA []byte) (int, error) { dAtA[i] = 0x2 i++ i = encodeVarintApi(dAtA, i, uint64(m.AdminRelocateRange.Size())) - n192, err := m.AdminRelocateRange.MarshalTo(dAtA[i:]) + n193, err := m.AdminRelocateRange.MarshalTo(dAtA[i:]) if err != nil { return 0, err } - i += n192 + i += n193 } return i, nil } @@ -14658,11 +14676,11 @@ func (m *RequestUnion_RecoverTxn) MarshalTo(dAtA []byte) (int, error) { dAtA[i] = 0x2 i++ i = encodeVarintApi(dAtA, i, uint64(m.RecoverTxn.Size())) - n193, err := m.RecoverTxn.MarshalTo(dAtA[i:]) + n194, err := m.RecoverTxn.MarshalTo(dAtA[i:]) if err != nil { return 0, err } - i += n193 + i += n194 } return i, nil } @@ -14674,11 +14692,11 @@ func (m *RequestUnion_AdminUnsplit) MarshalTo(dAtA []byte) (int, error) { dAtA[i] = 0x2 i++ i = encodeVarintApi(dAtA, i, uint64(m.AdminUnsplit.Size())) - n194, err := m.AdminUnsplit.MarshalTo(dAtA[i:]) + n195, err := m.AdminUnsplit.MarshalTo(dAtA[i:]) if err != nil { return 0, err } - i += n194 + i += n195 } return i, nil } @@ -14690,11 +14708,11 @@ func (m *RequestUnion_RevertRange) MarshalTo(dAtA []byte) (int, error) { dAtA[i] = 0x3 i++ i = encodeVarintApi(dAtA, i, uint64(m.RevertRange.Size())) - n195, err := m.RevertRange.MarshalTo(dAtA[i:]) + n196, err := m.RevertRange.MarshalTo(dAtA[i:]) if err != nil { return 0, err } - i += n195 + i += n196 } return i, nil } @@ -14714,11 +14732,11 @@ func (m *ResponseUnion) MarshalTo(dAtA []byte) (int, error) { var l int _ = l if m.Value != nil { - nn196, err := m.Value.MarshalTo(dAtA[i:]) + nn197, err := m.Value.MarshalTo(dAtA[i:]) if err != nil { return 0, err } - i += nn196 + i += nn197 } return i, nil } @@ -14729,11 +14747,11 @@ func (m *ResponseUnion_Get) MarshalTo(dAtA []byte) (int, error) { dAtA[i] = 0xa i++ i = encodeVarintApi(dAtA, i, uint64(m.Get.Size())) - n197, err := m.Get.MarshalTo(dAtA[i:]) + n198, err := m.Get.MarshalTo(dAtA[i:]) if err != nil { return 0, err } - i += n197 + i += n198 } return i, nil } @@ -14743,11 +14761,11 @@ func (m *ResponseUnion_Put) MarshalTo(dAtA []byte) (int, error) { dAtA[i] = 0x12 i++ i = encodeVarintApi(dAtA, i, uint64(m.Put.Size())) - n198, err := m.Put.MarshalTo(dAtA[i:]) + n199, err := m.Put.MarshalTo(dAtA[i:]) if err != nil { return 0, err } - i += n198 + i += n199 } return i, nil } @@ -14757,11 +14775,11 @@ func (m *ResponseUnion_ConditionalPut) MarshalTo(dAtA []byte) (int, error) { dAtA[i] = 0x1a i++ i = encodeVarintApi(dAtA, i, uint64(m.ConditionalPut.Size())) - n199, err := m.ConditionalPut.MarshalTo(dAtA[i:]) + n200, err := m.ConditionalPut.MarshalTo(dAtA[i:]) if err != nil { return 0, err } - i += n199 + i += n200 } return i, nil } @@ -14771,11 +14789,11 @@ func (m *ResponseUnion_Increment) MarshalTo(dAtA []byte) (int, error) { dAtA[i] = 0x22 i++ i = encodeVarintApi(dAtA, i, uint64(m.Increment.Size())) - n200, err := m.Increment.MarshalTo(dAtA[i:]) + n201, err := m.Increment.MarshalTo(dAtA[i:]) if err != nil { return 0, err } - i += n200 + i += n201 } return i, nil } @@ -14785,11 +14803,11 @@ func (m *ResponseUnion_Delete) MarshalTo(dAtA []byte) (int, error) { dAtA[i] = 0x2a i++ i = encodeVarintApi(dAtA, i, uint64(m.Delete.Size())) - n201, err := m.Delete.MarshalTo(dAtA[i:]) + n202, err := m.Delete.MarshalTo(dAtA[i:]) if err != nil { return 0, err } - i += n201 + i += n202 } return i, nil } @@ -14799,11 +14817,11 @@ func (m *ResponseUnion_DeleteRange) MarshalTo(dAtA []byte) (int, error) { dAtA[i] = 0x32 i++ i = encodeVarintApi(dAtA, i, uint64(m.DeleteRange.Size())) - n202, err := m.DeleteRange.MarshalTo(dAtA[i:]) + n203, err := m.DeleteRange.MarshalTo(dAtA[i:]) if err != nil { return 0, err } - i += n202 + i += n203 } return i, nil } @@ -14813,11 +14831,11 @@ func (m *ResponseUnion_Scan) MarshalTo(dAtA []byte) (int, error) { dAtA[i] = 0x3a i++ i = encodeVarintApi(dAtA, i, uint64(m.Scan.Size())) - n203, err := m.Scan.MarshalTo(dAtA[i:]) + n204, err := m.Scan.MarshalTo(dAtA[i:]) if err != nil { return 0, err } - i += n203 + i += n204 } return i, nil } @@ -14827,11 +14845,11 @@ func (m *ResponseUnion_BeginTransaction) MarshalTo(dAtA []byte) (int, error) { dAtA[i] = 0x42 i++ i = encodeVarintApi(dAtA, i, uint64(m.BeginTransaction.Size())) - n204, err := m.BeginTransaction.MarshalTo(dAtA[i:]) + n205, err := m.BeginTransaction.MarshalTo(dAtA[i:]) if err != nil { return 0, err } - i += n204 + i += n205 } return i, nil } @@ -14841,11 +14859,11 @@ func (m *ResponseUnion_EndTransaction) MarshalTo(dAtA []byte) (int, error) { dAtA[i] = 0x4a i++ i = encodeVarintApi(dAtA, i, uint64(m.EndTransaction.Size())) - n205, err := m.EndTransaction.MarshalTo(dAtA[i:]) + n206, err := m.EndTransaction.MarshalTo(dAtA[i:]) if err != nil { return 0, err } - i += n205 + i += n206 } return i, nil } @@ -14855,11 +14873,11 @@ func (m *ResponseUnion_AdminSplit) MarshalTo(dAtA []byte) (int, error) { dAtA[i] = 0x52 i++ i = encodeVarintApi(dAtA, i, uint64(m.AdminSplit.Size())) - n206, err := m.AdminSplit.MarshalTo(dAtA[i:]) + n207, err := m.AdminSplit.MarshalTo(dAtA[i:]) if err != nil { return 0, err } - i += n206 + i += n207 } return i, nil } @@ -14869,11 +14887,11 @@ func (m *ResponseUnion_AdminMerge) MarshalTo(dAtA []byte) (int, error) { dAtA[i] = 0x5a i++ i = encodeVarintApi(dAtA, i, uint64(m.AdminMerge.Size())) - n207, err := m.AdminMerge.MarshalTo(dAtA[i:]) + n208, err := m.AdminMerge.MarshalTo(dAtA[i:]) if err != nil { return 0, err } - i += n207 + i += n208 } return i, nil } @@ -14883,11 +14901,11 @@ func (m *ResponseUnion_HeartbeatTxn) MarshalTo(dAtA []byte) (int, error) { dAtA[i] = 0x62 i++ i = encodeVarintApi(dAtA, i, uint64(m.HeartbeatTxn.Size())) - n208, err := m.HeartbeatTxn.MarshalTo(dAtA[i:]) + n209, err := m.HeartbeatTxn.MarshalTo(dAtA[i:]) if err != nil { return 0, err } - i += n208 + i += n209 } return i, nil } @@ -14897,11 +14915,11 @@ func (m *ResponseUnion_Gc) MarshalTo(dAtA []byte) (int, error) { dAtA[i] = 0x6a i++ i = encodeVarintApi(dAtA, i, uint64(m.Gc.Size())) - n209, err := m.Gc.MarshalTo(dAtA[i:]) + n210, err := m.Gc.MarshalTo(dAtA[i:]) if err != nil { return 0, err } - i += n209 + i += n210 } return i, nil } @@ -14911,11 +14929,11 @@ func (m *ResponseUnion_PushTxn) MarshalTo(dAtA []byte) (int, error) { dAtA[i] = 0x72 i++ i = encodeVarintApi(dAtA, i, uint64(m.PushTxn.Size())) - n210, err := m.PushTxn.MarshalTo(dAtA[i:]) + n211, err := m.PushTxn.MarshalTo(dAtA[i:]) if err != nil { return 0, err } - i += n210 + i += n211 } return i, nil } @@ -14927,11 +14945,11 @@ func (m *ResponseUnion_ResolveIntent) MarshalTo(dAtA []byte) (int, error) { dAtA[i] = 0x1 i++ i = encodeVarintApi(dAtA, i, uint64(m.ResolveIntent.Size())) - n211, err := m.ResolveIntent.MarshalTo(dAtA[i:]) + n212, err := m.ResolveIntent.MarshalTo(dAtA[i:]) if err != nil { return 0, err } - i += n211 + i += n212 } return i, nil } @@ -14943,11 +14961,11 @@ func (m *ResponseUnion_ResolveIntentRange) MarshalTo(dAtA []byte) (int, error) { dAtA[i] = 0x1 i++ i = encodeVarintApi(dAtA, i, uint64(m.ResolveIntentRange.Size())) - n212, err := m.ResolveIntentRange.MarshalTo(dAtA[i:]) + n213, err := m.ResolveIntentRange.MarshalTo(dAtA[i:]) if err != nil { return 0, err } - i += n212 + i += n213 } return i, nil } @@ -14959,11 +14977,11 @@ func (m *ResponseUnion_Merge) MarshalTo(dAtA []byte) (int, error) { dAtA[i] = 0x1 i++ i = encodeVarintApi(dAtA, i, uint64(m.Merge.Size())) - n213, err := m.Merge.MarshalTo(dAtA[i:]) + n214, err := m.Merge.MarshalTo(dAtA[i:]) if err != nil { return 0, err } - i += n213 + i += n214 } return i, nil } @@ -14975,11 +14993,11 @@ func (m *ResponseUnion_TruncateLog) MarshalTo(dAtA []byte) (int, error) { dAtA[i] = 0x1 i++ i = encodeVarintApi(dAtA, i, uint64(m.TruncateLog.Size())) - n214, err := m.TruncateLog.MarshalTo(dAtA[i:]) + n215, err := m.TruncateLog.MarshalTo(dAtA[i:]) if err != nil { return 0, err } - i += n214 + i += n215 } return i, nil } @@ -14991,11 +15009,11 @@ func (m *ResponseUnion_RequestLease) MarshalTo(dAtA []byte) (int, error) { dAtA[i] = 0x1 i++ i = encodeVarintApi(dAtA, i, uint64(m.RequestLease.Size())) - n215, err := m.RequestLease.MarshalTo(dAtA[i:]) + n216, err := m.RequestLease.MarshalTo(dAtA[i:]) if err != nil { return 0, err } - i += n215 + i += n216 } return i, nil } @@ -15007,11 +15025,11 @@ func (m *ResponseUnion_ReverseScan) MarshalTo(dAtA []byte) (int, error) { dAtA[i] = 0x1 i++ i = encodeVarintApi(dAtA, i, uint64(m.ReverseScan.Size())) - n216, err := m.ReverseScan.MarshalTo(dAtA[i:]) + n217, err := m.ReverseScan.MarshalTo(dAtA[i:]) if err != nil { return 0, err } - i += n216 + i += n217 } return i, nil } @@ -15023,11 +15041,11 @@ func (m *ResponseUnion_ComputeChecksum) MarshalTo(dAtA []byte) (int, error) { dAtA[i] = 0x1 i++ i = encodeVarintApi(dAtA, i, uint64(m.ComputeChecksum.Size())) - n217, err := m.ComputeChecksum.MarshalTo(dAtA[i:]) + n218, err := m.ComputeChecksum.MarshalTo(dAtA[i:]) if err != nil { return 0, err } - i += n217 + i += n218 } return i, nil } @@ -15039,11 +15057,11 @@ func (m *ResponseUnion_CheckConsistency) MarshalTo(dAtA []byte) (int, error) { dAtA[i] = 0x1 i++ i = encodeVarintApi(dAtA, i, uint64(m.CheckConsistency.Size())) - n218, err := m.CheckConsistency.MarshalTo(dAtA[i:]) + n219, err := m.CheckConsistency.MarshalTo(dAtA[i:]) if err != nil { return 0, err } - i += n218 + i += n219 } return i, nil } @@ -15055,11 +15073,11 @@ func (m *ResponseUnion_InitPut) MarshalTo(dAtA []byte) (int, error) { dAtA[i] = 0x1 i++ i = encodeVarintApi(dAtA, i, uint64(m.InitPut.Size())) - n219, err := m.InitPut.MarshalTo(dAtA[i:]) + n220, err := m.InitPut.MarshalTo(dAtA[i:]) if err != nil { return 0, err } - i += n219 + i += n220 } return i, nil } @@ -15071,11 +15089,11 @@ func (m *ResponseUnion_AdminTransferLease) MarshalTo(dAtA []byte) (int, error) { dAtA[i] = 0x1 i++ i = encodeVarintApi(dAtA, i, uint64(m.AdminTransferLease.Size())) - n220, err := m.AdminTransferLease.MarshalTo(dAtA[i:]) + n221, err := m.AdminTransferLease.MarshalTo(dAtA[i:]) if err != nil { return 0, err } - i += n220 + i += n221 } return i, nil } @@ -15087,11 +15105,11 @@ func (m *ResponseUnion_LeaseInfo) MarshalTo(dAtA []byte) (int, error) { dAtA[i] = 0x1 i++ i = encodeVarintApi(dAtA, i, uint64(m.LeaseInfo.Size())) - n221, err := m.LeaseInfo.MarshalTo(dAtA[i:]) + n222, err := m.LeaseInfo.MarshalTo(dAtA[i:]) if err != nil { return 0, err } - i += n221 + i += n222 } return i, nil } @@ -15103,11 +15121,11 @@ func (m *ResponseUnion_WriteBatch) MarshalTo(dAtA []byte) (int, error) { dAtA[i] = 0x1 i++ i = encodeVarintApi(dAtA, i, uint64(m.WriteBatch.Size())) - n222, err := m.WriteBatch.MarshalTo(dAtA[i:]) + n223, err := m.WriteBatch.MarshalTo(dAtA[i:]) if err != nil { return 0, err } - i += n222 + i += n223 } return i, nil } @@ -15119,11 +15137,11 @@ func (m *ResponseUnion_Export) MarshalTo(dAtA []byte) (int, error) { dAtA[i] = 0x2 i++ i = encodeVarintApi(dAtA, i, uint64(m.Export.Size())) - n223, err := m.Export.MarshalTo(dAtA[i:]) + n224, err := m.Export.MarshalTo(dAtA[i:]) if err != nil { return 0, err } - i += n223 + i += n224 } return i, nil } @@ -15135,11 +15153,11 @@ func (m *ResponseUnion_QueryTxn) MarshalTo(dAtA []byte) (int, error) { dAtA[i] = 0x2 i++ i = encodeVarintApi(dAtA, i, uint64(m.QueryTxn.Size())) - n224, err := m.QueryTxn.MarshalTo(dAtA[i:]) + n225, err := m.QueryTxn.MarshalTo(dAtA[i:]) if err != nil { return 0, err } - i += n224 + i += n225 } return i, nil } @@ -15151,11 +15169,11 @@ func (m *ResponseUnion_Import) MarshalTo(dAtA []byte) (int, error) { dAtA[i] = 0x2 i++ i = encodeVarintApi(dAtA, i, uint64(m.Import.Size())) - n225, err := m.Import.MarshalTo(dAtA[i:]) + n226, err := m.Import.MarshalTo(dAtA[i:]) if err != nil { return 0, err } - i += n225 + i += n226 } return i, nil } @@ -15167,11 +15185,11 @@ func (m *ResponseUnion_AdminChangeReplicas) MarshalTo(dAtA []byte) (int, error) dAtA[i] = 0x2 i++ i = encodeVarintApi(dAtA, i, uint64(m.AdminChangeReplicas.Size())) - n226, err := m.AdminChangeReplicas.MarshalTo(dAtA[i:]) + n227, err := m.AdminChangeReplicas.MarshalTo(dAtA[i:]) if err != nil { return 0, err } - i += n226 + i += n227 } return i, nil } @@ -15183,11 +15201,11 @@ func (m *ResponseUnion_AdminScatter) MarshalTo(dAtA []byte) (int, error) { dAtA[i] = 0x2 i++ i = encodeVarintApi(dAtA, i, uint64(m.AdminScatter.Size())) - n227, err := m.AdminScatter.MarshalTo(dAtA[i:]) + n228, err := m.AdminScatter.MarshalTo(dAtA[i:]) if err != nil { return 0, err } - i += n227 + i += n228 } return i, nil } @@ -15199,11 +15217,11 @@ func (m *ResponseUnion_AddSstable) MarshalTo(dAtA []byte) (int, error) { dAtA[i] = 0x2 i++ i = encodeVarintApi(dAtA, i, uint64(m.AddSstable.Size())) - n228, err := m.AddSstable.MarshalTo(dAtA[i:]) + n229, err := m.AddSstable.MarshalTo(dAtA[i:]) if err != nil { return 0, err } - i += n228 + i += n229 } return i, nil } @@ -15215,11 +15233,11 @@ func (m *ResponseUnion_ClearRange) MarshalTo(dAtA []byte) (int, error) { dAtA[i] = 0x2 i++ i = encodeVarintApi(dAtA, i, uint64(m.ClearRange.Size())) - n229, err := m.ClearRange.MarshalTo(dAtA[i:]) + n230, err := m.ClearRange.MarshalTo(dAtA[i:]) if err != nil { return 0, err } - i += n229 + i += n230 } return i, nil } @@ -15231,11 +15249,11 @@ func (m *ResponseUnion_RecomputeStats) MarshalTo(dAtA []byte) (int, error) { dAtA[i] = 0x2 i++ i = encodeVarintApi(dAtA, i, uint64(m.RecomputeStats.Size())) - n230, err := m.RecomputeStats.MarshalTo(dAtA[i:]) + n231, err := m.RecomputeStats.MarshalTo(dAtA[i:]) if err != nil { return 0, err } - i += n230 + i += n231 } return i, nil } @@ -15247,11 +15265,11 @@ func (m *ResponseUnion_Refresh) MarshalTo(dAtA []byte) (int, error) { dAtA[i] = 0x2 i++ i = encodeVarintApi(dAtA, i, uint64(m.Refresh.Size())) - n231, err := m.Refresh.MarshalTo(dAtA[i:]) + n232, err := m.Refresh.MarshalTo(dAtA[i:]) if err != nil { return 0, err } - i += n231 + i += n232 } return i, nil } @@ -15263,11 +15281,11 @@ func (m *ResponseUnion_RefreshRange) MarshalTo(dAtA []byte) (int, error) { dAtA[i] = 0x2 i++ i = encodeVarintApi(dAtA, i, uint64(m.RefreshRange.Size())) - n232, err := m.RefreshRange.MarshalTo(dAtA[i:]) + n233, err := m.RefreshRange.MarshalTo(dAtA[i:]) if err != nil { return 0, err } - i += n232 + i += n233 } return i, nil } @@ -15279,11 +15297,11 @@ func (m *ResponseUnion_QueryIntent) MarshalTo(dAtA []byte) (int, error) { dAtA[i] = 0x2 i++ i = encodeVarintApi(dAtA, i, uint64(m.QueryIntent.Size())) - n233, err := m.QueryIntent.MarshalTo(dAtA[i:]) + n234, err := m.QueryIntent.MarshalTo(dAtA[i:]) if err != nil { return 0, err } - i += n233 + i += n234 } return i, nil } @@ -15295,11 +15313,11 @@ func (m *ResponseUnion_Subsume) MarshalTo(dAtA []byte) (int, error) { dAtA[i] = 0x2 i++ i = encodeVarintApi(dAtA, i, uint64(m.Subsume.Size())) - n234, err := m.Subsume.MarshalTo(dAtA[i:]) + n235, err := m.Subsume.MarshalTo(dAtA[i:]) if err != nil { return 0, err } - i += n234 + i += n235 } return i, nil } @@ -15311,11 +15329,11 @@ func (m *ResponseUnion_RangeStats) MarshalTo(dAtA []byte) (int, error) { dAtA[i] = 0x2 i++ i = encodeVarintApi(dAtA, i, uint64(m.RangeStats.Size())) - n235, err := m.RangeStats.MarshalTo(dAtA[i:]) + n236, err := m.RangeStats.MarshalTo(dAtA[i:]) if err != nil { return 0, err } - i += n235 + i += n236 } return i, nil } @@ -15327,11 +15345,11 @@ func (m *ResponseUnion_AdminRelocateRange) MarshalTo(dAtA []byte) (int, error) { dAtA[i] = 0x2 i++ i = encodeVarintApi(dAtA, i, uint64(m.AdminRelocateRange.Size())) - n236, err := m.AdminRelocateRange.MarshalTo(dAtA[i:]) + n237, err := m.AdminRelocateRange.MarshalTo(dAtA[i:]) if err != nil { return 0, err } - i += n236 + i += n237 } return i, nil } @@ -15343,11 +15361,11 @@ func (m *ResponseUnion_RecoverTxn) MarshalTo(dAtA []byte) (int, error) { dAtA[i] = 0x2 i++ i = encodeVarintApi(dAtA, i, uint64(m.RecoverTxn.Size())) - n237, err := m.RecoverTxn.MarshalTo(dAtA[i:]) + n238, err := m.RecoverTxn.MarshalTo(dAtA[i:]) if err != nil { return 0, err } - i += n237 + i += n238 } return i, nil } @@ -15359,11 +15377,11 @@ func (m *ResponseUnion_AdminUnsplit) MarshalTo(dAtA []byte) (int, error) { dAtA[i] = 0x2 i++ i = encodeVarintApi(dAtA, i, uint64(m.AdminUnsplit.Size())) - n238, err := m.AdminUnsplit.MarshalTo(dAtA[i:]) + n239, err := m.AdminUnsplit.MarshalTo(dAtA[i:]) if err != nil { return 0, err } - i += n238 + i += n239 } return i, nil } @@ -15375,11 +15393,11 @@ func (m *ResponseUnion_RevertRange) MarshalTo(dAtA []byte) (int, error) { dAtA[i] = 0x3 i++ i = encodeVarintApi(dAtA, i, uint64(m.RevertRange.Size())) - n239, err := m.RevertRange.MarshalTo(dAtA[i:]) + n240, err := m.RevertRange.MarshalTo(dAtA[i:]) if err != nil { return 0, err } - i += n239 + i += n240 } return i, nil } @@ -15401,19 +15419,19 @@ func (m *Header) MarshalTo(dAtA []byte) (int, error) { dAtA[i] = 0xa i++ i = encodeVarintApi(dAtA, i, uint64(m.Timestamp.Size())) - n240, err := m.Timestamp.MarshalTo(dAtA[i:]) + n241, err := m.Timestamp.MarshalTo(dAtA[i:]) if err != nil { return 0, err } - i += n240 + i += n241 dAtA[i] = 0x12 i++ i = encodeVarintApi(dAtA, i, uint64(m.Replica.Size())) - n241, err := m.Replica.MarshalTo(dAtA[i:]) + n242, err := m.Replica.MarshalTo(dAtA[i:]) if err != nil { return 0, err } - i += n241 + i += n242 if m.RangeID != 0 { dAtA[i] = 0x18 i++ @@ -15429,11 +15447,11 @@ func (m *Header) MarshalTo(dAtA []byte) (int, error) { dAtA[i] = 0x2a i++ i = encodeVarintApi(dAtA, i, uint64(m.Txn.Size())) - n242, err := m.Txn.MarshalTo(dAtA[i:]) + n243, err := m.Txn.MarshalTo(dAtA[i:]) if err != nil { return 0, err } - i += n242 + i += n243 } if m.ReadConsistency != 0 { dAtA[i] = 0x30 @@ -15474,11 +15492,11 @@ func (m *Header) MarshalTo(dAtA []byte) (int, error) { dAtA[i] = 0x62 i++ i = encodeVarintApi(dAtA, i, uint64(m.ScanOptions.Size())) - n243, err := m.ScanOptions.MarshalTo(dAtA[i:]) + n244, err := m.ScanOptions.MarshalTo(dAtA[i:]) if err != nil { return 0, err } - i += n243 + i += n244 } if m.AsyncConsensus { dAtA[i] = 0x68 @@ -15521,11 +15539,11 @@ func (m *BatchRequest) MarshalTo(dAtA []byte) (int, error) { dAtA[i] = 0xa i++ i = encodeVarintApi(dAtA, i, uint64(m.Header.Size())) - n244, err := m.Header.MarshalTo(dAtA[i:]) + n245, err := m.Header.MarshalTo(dAtA[i:]) if err != nil { return 0, err } - i += n244 + i += n245 if len(m.Requests) > 0 { for _, msg := range m.Requests { dAtA[i] = 0x12 @@ -15559,11 +15577,11 @@ func (m *BatchResponse) MarshalTo(dAtA []byte) (int, error) { dAtA[i] = 0xa i++ i = encodeVarintApi(dAtA, i, uint64(m.BatchResponse_Header.Size())) - n245, err := m.BatchResponse_Header.MarshalTo(dAtA[i:]) + n246, err := m.BatchResponse_Header.MarshalTo(dAtA[i:]) if err != nil { return 0, err } - i += n245 + i += n246 if len(m.Responses) > 0 { for _, msg := range m.Responses { dAtA[i] = 0x12 @@ -15598,38 +15616,38 @@ func (m *BatchResponse_Header) MarshalTo(dAtA []byte) (int, error) { dAtA[i] = 0xa i++ i = encodeVarintApi(dAtA, i, uint64(m.Error.Size())) - n246, err := m.Error.MarshalTo(dAtA[i:]) + n247, err := m.Error.MarshalTo(dAtA[i:]) if err != nil { return 0, err } - i += n246 + i += n247 } dAtA[i] = 0x12 i++ i = encodeVarintApi(dAtA, i, uint64(m.Timestamp.Size())) - n247, err := m.Timestamp.MarshalTo(dAtA[i:]) + n248, err := m.Timestamp.MarshalTo(dAtA[i:]) if err != nil { return 0, err } - i += n247 + i += n248 if m.Txn != nil { dAtA[i] = 0x1a i++ i = encodeVarintApi(dAtA, i, uint64(m.Txn.Size())) - n248, err := m.Txn.MarshalTo(dAtA[i:]) + n249, err := m.Txn.MarshalTo(dAtA[i:]) if err != nil { return 0, err } - i += n248 + i += n249 } dAtA[i] = 0x2a i++ i = encodeVarintApi(dAtA, i, uint64(m.Now.Size())) - n249, err := m.Now.MarshalTo(dAtA[i:]) + n250, err := m.Now.MarshalTo(dAtA[i:]) if err != nil { return 0, err } - i += n249 + i += n250 if len(m.CollectedSpans) > 0 { for _, msg := range m.CollectedSpans { dAtA[i] = 0x32 @@ -15663,19 +15681,19 @@ func (m *RangeFeedRequest) MarshalTo(dAtA []byte) (int, error) { dAtA[i] = 0xa i++ i = encodeVarintApi(dAtA, i, uint64(m.Header.Size())) - n250, err := m.Header.MarshalTo(dAtA[i:]) + n251, err := m.Header.MarshalTo(dAtA[i:]) if err != nil { return 0, err } - i += n250 + i += n251 dAtA[i] = 0x12 i++ i = encodeVarintApi(dAtA, i, uint64(m.Span.Size())) - n251, err := m.Span.MarshalTo(dAtA[i:]) + n252, err := m.Span.MarshalTo(dAtA[i:]) if err != nil { return 0, err } - i += n251 + i += n252 return i, nil } @@ -15703,11 +15721,11 @@ func (m *RangeFeedValue) MarshalTo(dAtA []byte) (int, error) { dAtA[i] = 0x12 i++ i = encodeVarintApi(dAtA, i, uint64(m.Value.Size())) - n252, err := m.Value.MarshalTo(dAtA[i:]) + n253, err := m.Value.MarshalTo(dAtA[i:]) if err != nil { return 0, err } - i += n252 + i += n253 return i, nil } @@ -15729,19 +15747,19 @@ func (m *RangeFeedCheckpoint) MarshalTo(dAtA []byte) (int, error) { dAtA[i] = 0xa i++ i = encodeVarintApi(dAtA, i, uint64(m.Span.Size())) - n253, err := m.Span.MarshalTo(dAtA[i:]) + n254, err := m.Span.MarshalTo(dAtA[i:]) if err != nil { return 0, err } - i += n253 + i += n254 dAtA[i] = 0x12 i++ i = encodeVarintApi(dAtA, i, uint64(m.ResolvedTS.Size())) - n254, err := m.ResolvedTS.MarshalTo(dAtA[i:]) + n255, err := m.ResolvedTS.MarshalTo(dAtA[i:]) if err != nil { return 0, err } - i += n254 + i += n255 return i, nil } @@ -15763,11 +15781,11 @@ func (m *RangeFeedError) MarshalTo(dAtA []byte) (int, error) { dAtA[i] = 0xa i++ i = encodeVarintApi(dAtA, i, uint64(m.Error.Size())) - n255, err := m.Error.MarshalTo(dAtA[i:]) + n256, err := m.Error.MarshalTo(dAtA[i:]) if err != nil { return 0, err } - i += n255 + i += n256 return i, nil } @@ -15790,31 +15808,31 @@ func (m *RangeFeedEvent) MarshalTo(dAtA []byte) (int, error) { dAtA[i] = 0xa i++ i = encodeVarintApi(dAtA, i, uint64(m.Val.Size())) - n256, err := m.Val.MarshalTo(dAtA[i:]) + n257, err := m.Val.MarshalTo(dAtA[i:]) if err != nil { return 0, err } - i += n256 + i += n257 } if m.Checkpoint != nil { dAtA[i] = 0x12 i++ i = encodeVarintApi(dAtA, i, uint64(m.Checkpoint.Size())) - n257, err := m.Checkpoint.MarshalTo(dAtA[i:]) + n258, err := m.Checkpoint.MarshalTo(dAtA[i:]) if err != nil { return 0, err } - i += n257 + i += n258 } if m.Error != nil { dAtA[i] = 0x1a i++ i = encodeVarintApi(dAtA, i, uint64(m.Error.Size())) - n258, err := m.Error.MarshalTo(dAtA[i:]) + n259, err := m.Error.MarshalTo(dAtA[i:]) if err != nil { return 0, err } - i += n258 + i += n259 } return i, nil } @@ -17441,6 +17459,10 @@ func (m *AddSSTableRequest) Size() (n int) { if m.DisallowShadowing { n += 2 } + if m.MVCCStats != nil { + l = m.MVCCStats.Size() + n += 1 + l + sovApi(uint64(l)) + } return n } @@ -30672,6 +30694,39 @@ func (m *AddSSTableRequest) Unmarshal(dAtA []byte) error { } } m.DisallowShadowing = bool(v != 0) + case 4: + if wireType != 2 { + return fmt.Errorf("proto: wrong wireType = %d for field MVCCStats", wireType) + } + var msglen int + for shift := uint(0); ; shift += 7 { + if shift >= 64 { + return ErrIntOverflowApi + } + if iNdEx >= l { + return io.ErrUnexpectedEOF + } + b := dAtA[iNdEx] + iNdEx++ + msglen |= (int(b) & 0x7F) << shift + if b < 0x80 { + break + } + } + if msglen < 0 { + return ErrInvalidLengthApi + } + postIndex := iNdEx + msglen + if postIndex > l { + return io.ErrUnexpectedEOF + } + if m.MVCCStats == nil { + m.MVCCStats = &enginepb.MVCCStats{} + } + if err := m.MVCCStats.Unmarshal(dAtA[iNdEx:postIndex]); err != nil { + return err + } + iNdEx = postIndex default: iNdEx = preIndex skippy, err := skipApi(dAtA[iNdEx:]) @@ -35957,433 +36012,434 @@ var ( ErrIntOverflowApi = fmt.Errorf("proto: integer overflow") ) -func init() { proto.RegisterFile("roachpb/api.proto", fileDescriptor_api_0e495ec1ebba5dd6) } - -var fileDescriptor_api_0e495ec1ebba5dd6 = []byte{ - // 6790 bytes of a gzipped FileDescriptorProto - 0x1f, 0x8b, 0x08, 0x00, 0x00, 0x00, 0x00, 0x00, 0x02, 0xff, 0xe4, 0x5d, 0x4b, 0x6c, 0x23, 0xc9, - 0x79, 0x66, 0x93, 0x14, 0x45, 0xfe, 0x7c, 0xa8, 0x55, 0x9a, 0x07, 0x47, 0xbb, 0x2b, 0x69, 0x38, - 0xcf, 0x9d, 0xdd, 0xd5, 0x78, 0x66, 0xbc, 0xf1, 0x66, 0xd7, 0x5e, 0x5b, 0xa2, 0x38, 0x43, 0x8e, - 0x46, 0x8f, 0x6d, 0x52, 0xb3, 0x9e, 0x75, 0x36, 0xed, 0x56, 0x77, 0x89, 0x6a, 0x0f, 0xd9, 0xcd, - 0xed, 0x6e, 0x8e, 0xa4, 0x01, 0x82, 0x00, 0xb9, 0x38, 0x30, 0x0c, 0x23, 0x87, 0x20, 0x08, 0xec, - 0x04, 0x59, 0xc0, 0x01, 0x02, 0x24, 0x88, 0x91, 0x00, 0x06, 0xf2, 0x40, 0x00, 0x1f, 0x92, 0xc3, - 0xc6, 0xf0, 0x61, 0x11, 0xc4, 0x8e, 0x91, 0x83, 0x90, 0x8c, 0x13, 0xd8, 0xc8, 0x35, 0x40, 0x0c, - 0xec, 0x21, 0x08, 0xea, 0xd1, 0x0f, 0x92, 0xcd, 0x87, 0xe4, 0x5e, 0x64, 0x83, 0x9c, 0xd8, 0xfd, - 0x57, 0xfd, 0x7f, 0x57, 0xfd, 0xf5, 0x57, 0xd5, 0xff, 0x55, 0xfd, 0x55, 0x84, 0x59, 0xcb, 0x54, - 0xd4, 0xfd, 0xce, 0xee, 0x4d, 0xa5, 0xa3, 0x2f, 0x77, 0x2c, 0xd3, 0x31, 0xd1, 0xac, 0x6a, 0xaa, - 0x8f, 0x29, 0x79, 0x99, 0x27, 0xce, 0x23, 0x37, 0x97, 0xa6, 0x38, 0x0a, 0xcb, 0x36, 0x7f, 0xc6, - 0xa5, 0x61, 0xcb, 0x32, 0x2d, 0x9b, 0x53, 0xcf, 0xb9, 0xd4, 0x36, 0x76, 0x94, 0x40, 0xee, 0x92, - 0xed, 0x98, 0x96, 0xd2, 0xc4, 0x37, 0xb1, 0xd1, 0xd4, 0x0d, 0xf7, 0x87, 0xe4, 0x7b, 0xa2, 0xaa, - 0x3c, 0xcf, 0xa5, 0x51, 0x79, 0xee, 0xf0, 0x4c, 0xc5, 0xae, 0xa3, 0xb7, 0x6e, 0xee, 0xb7, 0xd4, - 0x9b, 0x8e, 0xde, 0xc6, 0xb6, 0xa3, 0xb4, 0x3b, 0x3c, 0x65, 0x89, 0xa6, 0x38, 0x96, 0xa2, 0xea, - 0x46, 0xf3, 0xa6, 0x85, 0x55, 0xd3, 0xd2, 0xb0, 0x26, 0xdb, 0x1d, 0xc5, 0x70, 0x8b, 0xdc, 0x34, - 0x9b, 0x26, 0x7d, 0xbc, 0x49, 0x9e, 0x18, 0xb5, 0xf4, 0xeb, 0x90, 0x91, 0x14, 0xa3, 0x89, 0x6b, - 0xc6, 0x9e, 0x89, 0x3e, 0x0b, 0x49, 0x0d, 0xdb, 0x6a, 0x51, 0x58, 0x12, 0xae, 0x67, 0x6f, 0x97, - 0x96, 0x07, 0x74, 0xb1, 0x4c, 0xf3, 0xae, 0x61, 0x5b, 0xb5, 0xf4, 0x8e, 0x63, 0x5a, 0xab, 0xc9, - 0x0f, 0x8e, 0x17, 0x63, 0x12, 0xe5, 0x42, 0x9f, 0x86, 0xa9, 0x16, 0x56, 0x6c, 0x5c, 0x8c, 0x53, - 0xf6, 0x62, 0x08, 0xfb, 0x03, 0x92, 0xce, 0x99, 0x58, 0xe6, 0xd2, 0xdf, 0x0a, 0x90, 0x97, 0xf0, - 0x7b, 0x5d, 0x6c, 0x3b, 0x55, 0xac, 0x68, 0xd8, 0x42, 0x17, 0x20, 0xf1, 0x18, 0x1f, 0x15, 0x13, - 0x4b, 0xc2, 0xf5, 0xdc, 0xea, 0xf4, 0x47, 0xc7, 0x8b, 0x89, 0x75, 0x7c, 0x24, 0x11, 0x1a, 0x5a, - 0x82, 0x69, 0x6c, 0x68, 0x32, 0x49, 0x4e, 0xf6, 0x26, 0xa7, 0xb0, 0xa1, 0xad, 0xe3, 0x23, 0xa4, - 0x42, 0xda, 0x26, 0xd2, 0x0c, 0x15, 0x17, 0xa7, 0x96, 0x84, 0xeb, 0x53, 0xab, 0xf7, 0x3e, 0x3a, - 0x5e, 0x2c, 0x37, 0x75, 0x67, 0xbf, 0xbb, 0xbb, 0xac, 0x9a, 0xed, 0x9b, 0x5e, 0xa9, 0xb4, 0x5d, - 0xff, 0xf9, 0x66, 0xe7, 0x71, 0xf3, 0xe6, 0x90, 0x16, 0x58, 0x6e, 0x1c, 0x1a, 0x75, 0xfc, 0x9e, - 0xe4, 0x09, 0x7e, 0x3d, 0xf9, 0xb3, 0xf7, 0x17, 0x85, 0xfb, 0xc9, 0xb4, 0x20, 0xc6, 0xef, 0x27, - 0xd3, 0x71, 0x31, 0x51, 0xfa, 0x7a, 0x02, 0x0a, 0x12, 0xb6, 0x3b, 0xa6, 0x61, 0x63, 0x5e, 0x8d, - 0x4f, 0x41, 0xc2, 0x39, 0x34, 0x68, 0x35, 0xb2, 0xb7, 0x17, 0x42, 0x94, 0xd1, 0xb0, 0x14, 0xc3, - 0x56, 0x54, 0x47, 0x37, 0x0d, 0x89, 0x64, 0x45, 0xaf, 0x41, 0xd6, 0xc2, 0x76, 0xb7, 0x8d, 0x69, - 0xb3, 0xd1, 0x1a, 0x66, 0x6f, 0x9f, 0x0f, 0xe1, 0xac, 0x77, 0x14, 0x43, 0x02, 0x96, 0x97, 0x3c, - 0xa3, 0x0b, 0x90, 0x36, 0xba, 0x6d, 0xa2, 0x17, 0x9b, 0xd6, 0x3a, 0x21, 0x4d, 0x1b, 0xdd, 0xf6, - 0x3a, 0x3e, 0xb2, 0x51, 0x19, 0xb2, 0x16, 0x69, 0x34, 0x59, 0x37, 0xf6, 0x4c, 0xbb, 0x98, 0x5a, - 0x4a, 0x5c, 0xcf, 0xde, 0x7e, 0x7e, 0x58, 0xd3, 0x12, 0x33, 0xe0, 0xed, 0x03, 0x96, 0x4b, 0xb0, - 0x51, 0x1d, 0xf2, 0xbc, 0x64, 0x16, 0x56, 0x6c, 0xd3, 0x28, 0x4e, 0x2f, 0x09, 0xd7, 0x0b, 0xb7, - 0x97, 0xc3, 0xc4, 0xf4, 0x68, 0x81, 0xbc, 0x76, 0xdb, 0x58, 0xa2, 0x5c, 0x52, 0xce, 0x0a, 0xbc, - 0x95, 0x1e, 0x41, 0x2e, 0x98, 0x8a, 0x10, 0x14, 0xa4, 0x4a, 0x7d, 0x67, 0xa3, 0x22, 0xef, 0x6c, - 0xae, 0x6f, 0x6e, 0xbd, 0xbd, 0x29, 0xc6, 0xd0, 0x19, 0x10, 0x39, 0x6d, 0xbd, 0xf2, 0x48, 0x7e, - 0x50, 0xdb, 0xa8, 0x35, 0x44, 0x01, 0x5d, 0x80, 0xb3, 0x9c, 0x2a, 0xad, 0x6c, 0xde, 0xab, 0xc8, - 0xab, 0x5b, 0x3b, 0x9b, 0x6b, 0x2b, 0xd2, 0x23, 0x31, 0x3e, 0x9f, 0xfc, 0xcd, 0x6f, 0x2f, 0xc4, - 0x4a, 0x0f, 0x01, 0xee, 0x61, 0x87, 0x9b, 0x15, 0x5a, 0x85, 0xd4, 0x3e, 0x2d, 0x0d, 0x37, 0xec, - 0xa5, 0xd0, 0x62, 0x07, 0x4c, 0x70, 0x35, 0x4d, 0x34, 0xf0, 0xe1, 0xf1, 0xa2, 0x20, 0x71, 0x4e, - 0xd6, 0xe4, 0xa5, 0xef, 0x09, 0x90, 0xa5, 0x82, 0x59, 0x1d, 0x51, 0xb9, 0x4f, 0xf2, 0xc5, 0xb1, - 0x0a, 0x19, 0x14, 0x8d, 0x96, 0x61, 0xea, 0x89, 0xd2, 0xea, 0x8e, 0xea, 0x37, 0x0f, 0x49, 0xba, - 0xc4, 0xb2, 0xa1, 0x37, 0x20, 0xa7, 0x1b, 0x0e, 0x36, 0x1c, 0x99, 0xb1, 0x25, 0xc6, 0xb0, 0x65, - 0x59, 0x6e, 0xfa, 0x52, 0xfa, 0x6b, 0x01, 0x60, 0xbb, 0x1b, 0xa5, 0x6a, 0x48, 0xbf, 0x9f, 0xa8, - 0xfc, 0x6e, 0xbf, 0x67, 0xb5, 0x38, 0x07, 0x29, 0xdd, 0x68, 0xe9, 0x06, 0x2b, 0x7f, 0x5a, 0xe2, - 0x6f, 0xe8, 0x0c, 0x4c, 0xed, 0xb6, 0x74, 0x43, 0xa3, 0xe6, 0x9f, 0x96, 0xd8, 0x0b, 0x57, 0xbf, - 0x04, 0x59, 0x5a, 0xf6, 0x08, 0xb5, 0x5f, 0xfa, 0x66, 0x1c, 0xce, 0x96, 0x4d, 0x43, 0xd3, 0x49, - 0x3f, 0x54, 0x5a, 0x9f, 0x08, 0xdd, 0xbc, 0x0a, 0x19, 0x7c, 0xd8, 0x99, 0xb0, 0x79, 0xd3, 0xf8, - 0xb0, 0x43, 0x9f, 0xc2, 0x55, 0x87, 0x3e, 0x0d, 0xe7, 0x95, 0x56, 0xcb, 0x3c, 0x90, 0xf5, 0x3d, - 0x59, 0x33, 0xb1, 0x2d, 0x1b, 0xa6, 0x23, 0xe3, 0x43, 0xdd, 0x76, 0xe8, 0x50, 0x91, 0x96, 0xe6, - 0x68, 0x72, 0x6d, 0x6f, 0xcd, 0xc4, 0xf6, 0xa6, 0xe9, 0x54, 0x48, 0x12, 0x57, 0xf8, 0xbb, 0x70, - 0xae, 0x5f, 0x37, 0x51, 0xea, 0xfe, 0x1f, 0x04, 0x28, 0xd4, 0x0c, 0xdd, 0xf9, 0x44, 0x28, 0xdd, - 0xd3, 0x5e, 0x22, 0xa8, 0xbd, 0x1b, 0x20, 0xee, 0x29, 0x7a, 0x6b, 0xcb, 0x68, 0x98, 0xed, 0x5d, - 0xdb, 0x31, 0x0d, 0x6c, 0x73, 0xf5, 0x0e, 0xd0, 0xb9, 0xce, 0x1e, 0xc2, 0x8c, 0x57, 0xa7, 0x28, - 0x95, 0xf5, 0x14, 0xc4, 0x9a, 0xa1, 0x5a, 0xb8, 0x8d, 0x8d, 0x48, 0xb5, 0xf5, 0x3c, 0x64, 0x74, - 0x57, 0x2e, 0xd5, 0x58, 0x42, 0xf2, 0x09, 0xbc, 0x4e, 0x5d, 0x98, 0x0d, 0x7c, 0x3b, 0xca, 0xc1, - 0xef, 0x39, 0xc8, 0x18, 0xf8, 0x40, 0xf6, 0xdb, 0x2b, 0x21, 0xa5, 0x0d, 0x7c, 0xc0, 0x06, 0xab, - 0x47, 0x90, 0x5f, 0xc3, 0x2d, 0xec, 0xe0, 0xe8, 0x47, 0xf2, 0x1d, 0x28, 0xb8, 0xa2, 0xa3, 0x6c, - 0xa4, 0xdf, 0x17, 0x00, 0x71, 0xb9, 0x64, 0xf6, 0x8c, 0xb2, 0x9d, 0x16, 0x89, 0x77, 0xe0, 0x74, - 0x2d, 0x83, 0x4d, 0xf3, 0xcc, 0x4a, 0x81, 0x91, 0xe8, 0x4c, 0xef, 0x8f, 0xa8, 0xc9, 0xe0, 0x88, - 0xea, 0x79, 0x2b, 0xc4, 0x4f, 0x39, 0x80, 0xb9, 0x9e, 0xe2, 0x45, 0xdb, 0x94, 0x49, 0x5a, 0xb2, - 0xf8, 0x52, 0x22, 0xe8, 0x99, 0x51, 0x62, 0xe9, 0x5d, 0x98, 0x2d, 0xb7, 0xb0, 0x62, 0x45, 0xad, - 0x16, 0xde, 0x9c, 0x8f, 0x00, 0x05, 0xc5, 0x47, 0xd9, 0xa4, 0x7f, 0x28, 0x00, 0x92, 0xf0, 0x13, - 0x6c, 0x39, 0x91, 0x37, 0xe9, 0x1a, 0x64, 0x1d, 0xc5, 0x6a, 0x62, 0x47, 0x26, 0xee, 0x3c, 0x1f, - 0xae, 0x5e, 0x08, 0x08, 0x22, 0x4e, 0xfd, 0xf2, 0x7e, 0x4b, 0x5d, 0x6e, 0xb8, 0xee, 0xbe, 0xeb, - 0x9c, 0x31, 0x3e, 0x42, 0xe6, 0x1a, 0x78, 0x07, 0xe6, 0x7a, 0x4a, 0x19, 0xa5, 0x0a, 0x74, 0xc8, - 0xd6, 0x55, 0xc5, 0xd8, 0xea, 0x90, 0x79, 0xc0, 0x46, 0x77, 0xe0, 0x9c, 0xed, 0x98, 0x1d, 0x59, - 0x71, 0x64, 0xe6, 0x5a, 0xee, 0x9a, 0x5d, 0x43, 0x53, 0xac, 0x23, 0xfa, 0x8d, 0xb4, 0x34, 0x47, - 0x52, 0x57, 0x58, 0x41, 0x56, 0x79, 0x12, 0x31, 0xdf, 0xb6, 0x6e, 0xc8, 0xc4, 0x03, 0x6c, 0x39, - 0x36, 0xef, 0xea, 0xd0, 0xd6, 0x0d, 0x89, 0x51, 0x78, 0x35, 0xbe, 0x2d, 0xb0, 0x6f, 0x45, 0xa9, - 0xe6, 0x37, 0x21, 0x6b, 0xab, 0x8a, 0x21, 0xef, 0x99, 0x56, 0x5b, 0x71, 0x68, 0xef, 0x28, 0xf4, - 0xa8, 0xd9, 0xf3, 0xab, 0x55, 0xc5, 0xb8, 0x4b, 0x33, 0x49, 0x60, 0x7b, 0xcf, 0xc1, 0x0e, 0x74, - 0x3f, 0x99, 0x4e, 0x88, 0xc9, 0xd2, 0xcf, 0x05, 0xc8, 0xb1, 0x52, 0x46, 0xd9, 0x81, 0x5e, 0x85, - 0xa4, 0x65, 0x1e, 0xb0, 0x0e, 0x94, 0xbd, 0xfd, 0x5c, 0x88, 0x88, 0x75, 0x7c, 0x14, 0x9c, 0xb9, - 0x68, 0x76, 0xb4, 0x0a, 0xdc, 0xc3, 0x93, 0x29, 0x77, 0x62, 0x52, 0x6e, 0x60, 0x5c, 0x12, 0x91, - 0x71, 0x0d, 0x66, 0x76, 0x15, 0x47, 0xdd, 0x27, 0xed, 0x43, 0x0b, 0x49, 0x66, 0xb9, 0xc4, 0xf5, - 0x9c, 0x54, 0xa0, 0x64, 0xb7, 0xe8, 0x76, 0xe9, 0x8f, 0xdd, 0xde, 0x60, 0xe3, 0x4f, 0x7e, 0x33, - 0xfd, 0xb7, 0xc0, 0x3b, 0x85, 0x5b, 0xd8, 0xff, 0x6f, 0xad, 0xf5, 0x43, 0x01, 0xce, 0x97, 0xf7, - 0xb1, 0xfa, 0xb8, 0x6c, 0x1a, 0xb6, 0x6e, 0x3b, 0xd8, 0x50, 0x8f, 0xa2, 0x6c, 0xb2, 0xe7, 0x20, - 0x73, 0xa0, 0x3b, 0xfb, 0xb2, 0xa6, 0xef, 0xed, 0xd1, 0x2e, 0x9d, 0x96, 0xd2, 0x84, 0xb0, 0xa6, - 0xef, 0xed, 0xa1, 0x3b, 0x90, 0x6c, 0x9b, 0x1a, 0x73, 0x60, 0x0b, 0xb7, 0x17, 0x43, 0xc4, 0xd3, - 0xa2, 0xd9, 0xdd, 0xf6, 0x86, 0xa9, 0x61, 0x89, 0x66, 0x46, 0x0b, 0x00, 0x2a, 0xa1, 0x76, 0x4c, - 0xdd, 0x70, 0xf8, 0x44, 0x16, 0xa0, 0xf0, 0x51, 0xe2, 0x1b, 0x49, 0x28, 0x0e, 0xd6, 0x2b, 0xca, - 0xd6, 0xdd, 0x86, 0x14, 0x1b, 0xaa, 0x78, 0xfb, 0xde, 0x1e, 0x56, 0xfc, 0x90, 0x12, 0x2c, 0xb3, - 0x21, 0x8d, 0x37, 0x1c, 0x97, 0x33, 0xff, 0x37, 0x02, 0xa4, 0x58, 0x02, 0xba, 0x05, 0x69, 0x8e, - 0xc9, 0x35, 0x5a, 0xc6, 0xc4, 0xea, 0xb9, 0x67, 0xc7, 0x8b, 0xd3, 0x0c, 0x81, 0xaf, 0x7d, 0xe4, - 0x3f, 0x4a, 0xd3, 0x0c, 0x84, 0x6b, 0x44, 0xd3, 0xb6, 0xa3, 0x58, 0x0e, 0x5d, 0xfb, 0x20, 0x9a, - 0xce, 0x49, 0x69, 0x4a, 0x58, 0xc7, 0x47, 0xe8, 0x3e, 0xa4, 0x6c, 0x47, 0x71, 0xba, 0x36, 0xd7, - 0xf5, 0x89, 0x0a, 0x5b, 0xa7, 0x9c, 0x12, 0x97, 0x40, 0xbc, 0x08, 0x0d, 0x3b, 0x8a, 0xde, 0xa2, - 0xca, 0xcf, 0x48, 0xfc, 0xad, 0xf4, 0x2d, 0x01, 0x52, 0x2c, 0x2b, 0x3a, 0x0f, 0x73, 0x0c, 0x77, - 0xd7, 0x36, 0xd7, 0x2a, 0x8d, 0x8a, 0xb4, 0x51, 0xdb, 0x5c, 0x69, 0x54, 0xc4, 0x18, 0x3a, 0x07, - 0xc8, 0x4d, 0x28, 0x6f, 0x6d, 0xd6, 0x6b, 0xf5, 0x46, 0x65, 0x93, 0xe0, 0x75, 0x82, 0xe2, 0x29, - 0x3d, 0x40, 0x8d, 0xa3, 0xcb, 0xb0, 0xd4, 0x4f, 0x95, 0xeb, 0x8d, 0x95, 0x46, 0x5d, 0xae, 0xd4, - 0x1b, 0xb5, 0x8d, 0x95, 0x46, 0x65, 0x4d, 0x4c, 0x8c, 0xc8, 0x45, 0x3e, 0x22, 0x49, 0x95, 0x72, - 0x43, 0x4c, 0x96, 0x9e, 0xc2, 0x59, 0x09, 0xab, 0x66, 0xbb, 0xd3, 0x75, 0x30, 0x29, 0xa5, 0x1d, - 0xa5, 0x95, 0x9f, 0x87, 0x69, 0xcd, 0x3a, 0x92, 0xad, 0xae, 0xc1, 0x6d, 0x3c, 0xa5, 0x59, 0x47, - 0x52, 0xd7, 0xe0, 0xc6, 0xf8, 0x17, 0x02, 0x9c, 0xeb, 0xff, 0x78, 0x94, 0xa6, 0xf8, 0x45, 0xc8, - 0x2a, 0x9a, 0x86, 0x35, 0x59, 0xc3, 0x2d, 0x47, 0xe1, 0x5e, 0xc2, 0xad, 0x80, 0x24, 0xbe, 0x6e, - 0xb5, 0xcc, 0x16, 0xac, 0x96, 0xbd, 0x75, 0xab, 0x8d, 0x87, 0xe5, 0x32, 0x2d, 0xcf, 0x1a, 0x61, - 0x74, 0xc7, 0x11, 0x2a, 0x8b, 0x52, 0x4a, 0x2a, 0x9c, 0x5f, 0xc5, 0x4d, 0xdd, 0x08, 0xae, 0x44, - 0x45, 0xee, 0x9a, 0xc9, 0x50, 0x1c, 0xfc, 0x48, 0xa4, 0x0e, 0x5a, 0x12, 0xce, 0x56, 0x0c, 0xed, - 0xe3, 0xa9, 0x04, 0xe9, 0x0f, 0xaa, 0xd9, 0x6e, 0xeb, 0x8e, 0xdb, 0xf6, 0xec, 0x0d, 0xfd, 0x32, - 0xa4, 0x35, 0xac, 0x68, 0xde, 0x0a, 0xc6, 0x38, 0xc7, 0x4d, 0xf2, 0xb2, 0xa3, 0x2f, 0xc3, 0x79, - 0x32, 0x98, 0x5b, 0x86, 0xd2, 0x92, 0x99, 0x34, 0xd9, 0xb1, 0xf4, 0x66, 0x13, 0x5b, 0x7c, 0xcd, - 0xef, 0x7a, 0x48, 0x39, 0x6b, 0x9c, 0xa3, 0x4c, 0x19, 0x1a, 0x2c, 0xbf, 0x74, 0x56, 0x0f, 0x23, - 0xa3, 0x2f, 0x78, 0x4b, 0x44, 0x76, 0x47, 0x31, 0xec, 0xe2, 0x14, 0x1d, 0xc3, 0x86, 0x2d, 0x25, - 0x72, 0xcb, 0xe0, 0xf3, 0x12, 0xa1, 0xd8, 0xe8, 0x26, 0x41, 0x1b, 0xef, 0x75, 0x75, 0x0b, 0xcb, - 0xb7, 0x3a, 0x6a, 0x31, 0x45, 0xea, 0xbe, 0x5a, 0x78, 0x76, 0xbc, 0x08, 0x12, 0x23, 0xdf, 0xda, - 0x2e, 0x13, 0xf4, 0xc1, 0x9e, 0x3b, 0x2a, 0xba, 0x0e, 0xa2, 0x61, 0xca, 0x16, 0xde, 0xb3, 0xb0, - 0xbd, 0xcf, 0x3f, 0x9b, 0xa6, 0x1a, 0x2b, 0x18, 0xa6, 0xc4, 0xc8, 0x4c, 0xf4, 0x39, 0x48, 0x75, - 0x4c, 0xdd, 0x36, 0x8d, 0x62, 0x86, 0x69, 0x94, 0xbd, 0xa1, 0xb7, 0x40, 0xd4, 0x0d, 0x79, 0xaf, - 0xa5, 0x37, 0xf7, 0x1d, 0xf9, 0xc0, 0xd2, 0x1d, 0x6c, 0x17, 0x67, 0x69, 0xc1, 0xc3, 0xcc, 0xa2, - 0xce, 0x17, 0x63, 0xb5, 0xb7, 0x49, 0x4e, 0x5e, 0x85, 0x82, 0x6e, 0xdc, 0xa5, 0xfc, 0x94, 0x68, - 0x7b, 0x2e, 0xc1, 0xb4, 0x98, 0x2e, 0xfd, 0xbb, 0x00, 0xe7, 0xfa, 0xcd, 0x24, 0xca, 0x6e, 0x7a, - 0x1d, 0x44, 0xd3, 0xc0, 0x72, 0x67, 0x5f, 0xb1, 0x31, 0x6f, 0x56, 0x3e, 0x7f, 0x15, 0x4c, 0x03, - 0x6f, 0x13, 0x32, 0x6b, 0x24, 0xb4, 0x0d, 0xb3, 0xb6, 0xa3, 0x34, 0x75, 0xa3, 0x29, 0x7b, 0xcb, - 0xf8, 0x74, 0x2d, 0x66, 0x42, 0xe7, 0x5f, 0xe4, 0xdc, 0x1e, 0xbd, 0xc7, 0xe9, 0xf9, 0x27, 0x01, - 0x66, 0x57, 0xb4, 0xb6, 0x6e, 0xd4, 0x3b, 0x2d, 0x3d, 0xd2, 0x95, 0x82, 0xcb, 0x90, 0xb1, 0x89, - 0x4c, 0x7f, 0x0e, 0xf2, 0x51, 0x5e, 0x9a, 0xa6, 0x90, 0xc9, 0xe8, 0x01, 0xcc, 0xe0, 0xc3, 0x8e, - 0x6e, 0x29, 0x44, 0xc5, 0x0c, 0xd8, 0x24, 0x27, 0xaf, 0x5b, 0xc1, 0xe7, 0xf5, 0xc1, 0x0d, 0xaf, - 0xd9, 0x23, 0x40, 0xc1, 0x8a, 0x45, 0x39, 0x86, 0xc8, 0x30, 0x47, 0x45, 0xef, 0x18, 0x76, 0xc4, - 0x5a, 0xe3, 0xa3, 0xe0, 0x97, 0xe0, 0x4c, 0xef, 0x07, 0xa2, 0x2c, 0xfd, 0xbb, 0xbc, 0xc5, 0x37, - 0xb0, 0xf5, 0x31, 0x81, 0xeb, 0xa0, 0xf8, 0x28, 0x4b, 0xfe, 0x35, 0x01, 0x2e, 0x50, 0xd9, 0xb4, - 0x5b, 0xee, 0x61, 0x8b, 0xee, 0x10, 0x45, 0x69, 0xb4, 0x97, 0x20, 0xc5, 0xb0, 0x32, 0xb5, 0xd8, - 0xa9, 0xd5, 0x2c, 0x71, 0xaf, 0xea, 0x8e, 0x69, 0x11, 0xf7, 0x8a, 0x27, 0xf1, 0x7a, 0x2a, 0x30, - 0x1f, 0x56, 0x96, 0x28, 0xeb, 0xfb, 0x97, 0x71, 0xfe, 0x8d, 0xf2, 0x3e, 0x83, 0xe9, 0x9d, 0x96, - 0xae, 0x2a, 0x91, 0x7a, 0x2b, 0x15, 0xc8, 0xaa, 0x54, 0xb8, 0xec, 0x1c, 0x75, 0xd8, 0xa2, 0x42, - 0xe1, 0xf6, 0xe5, 0x50, 0x41, 0xf4, 0xe3, 0xac, 0x24, 0x8d, 0xa3, 0x0e, 0x26, 0x8e, 0xb6, 0xfb, - 0x8c, 0xd6, 0x60, 0x9a, 0x29, 0xc7, 0xc5, 0x28, 0x23, 0x44, 0xd0, 0xde, 0x4a, 0x33, 0xf3, 0x5e, - 0xec, 0xb2, 0xa2, 0x32, 0xa4, 0xf1, 0x61, 0x47, 0xa6, 0xbb, 0x8a, 0xc9, 0x13, 0xee, 0x2a, 0x4e, - 0xe3, 0xc3, 0x0e, 0x21, 0xf2, 0xd6, 0x79, 0x5f, 0x80, 0xe7, 0x42, 0x55, 0x17, 0xe5, 0x20, 0xee, - 0xee, 0x80, 0xc6, 0x4f, 0xb3, 0x03, 0x5a, 0xfa, 0x13, 0xd7, 0x9a, 0x25, 0xdc, 0x32, 0x55, 0xe5, - 0x63, 0x58, 0x04, 0x0c, 0xb4, 0x4a, 0xfc, 0xd4, 0xad, 0xd2, 0x67, 0xee, 0x7d, 0x85, 0x8d, 0xd2, - 0xdc, 0x7f, 0x47, 0x80, 0xb9, 0x2a, 0x56, 0x2c, 0x67, 0x17, 0x2b, 0x4e, 0xe3, 0x30, 0x52, 0xc7, - 0xec, 0x55, 0x48, 0x18, 0xe6, 0xc1, 0x49, 0x16, 0xcd, 0x48, 0x7e, 0x7f, 0x38, 0xee, 0x2d, 0x57, - 0x94, 0xb5, 0xfe, 0xfb, 0x38, 0x64, 0xee, 0x95, 0xa3, 0xac, 0xeb, 0x67, 0xf9, 0xd2, 0x2a, 0xeb, - 0x89, 0x61, 0x66, 0xe9, 0x7d, 0x6f, 0xf9, 0x5e, 0x79, 0x1d, 0x1f, 0xb9, 0x66, 0x49, 0xb8, 0xd0, - 0x0a, 0x64, 0x9c, 0x7d, 0xe2, 0x7f, 0x99, 0x2d, 0xed, 0x24, 0x73, 0xb1, 0xcf, 0x35, 0xff, 0x18, - 0xa6, 0xa8, 0x5c, 0x77, 0x73, 0x5e, 0x08, 0xd9, 0x9c, 0x27, 0x9f, 0xf1, 0xdc, 0x99, 0xf8, 0x49, - 0x3e, 0xe3, 0x12, 0x58, 0xe3, 0x78, 0x73, 0xfe, 0x94, 0x98, 0x2a, 0xbd, 0x05, 0x40, 0xaa, 0x16, - 0x65, 0xf3, 0xfc, 0x55, 0x02, 0x0a, 0xdb, 0x5d, 0x7b, 0x3f, 0x62, 0x7b, 0x2c, 0x03, 0x74, 0xba, - 0xf6, 0x3e, 0xb6, 0x64, 0xe7, 0xd0, 0xe0, 0xf5, 0x1f, 0xb3, 0xed, 0xef, 0x2a, 0x80, 0xf1, 0x35, - 0x0e, 0x0d, 0xb4, 0xc5, 0x85, 0x60, 0xd9, 0x8f, 0x1d, 0xb8, 0x31, 0x01, 0xd4, 0x6b, 0x1c, 0x1a, - 0x1b, 0xd8, 0xc3, 0x78, 0x4c, 0x20, 0x26, 0x02, 0x3f, 0x0b, 0xd3, 0xe4, 0x45, 0x76, 0xcc, 0x93, - 0xb4, 0x7c, 0x8a, 0xf0, 0x34, 0x4c, 0xf4, 0x06, 0x64, 0x18, 0x37, 0x99, 0x49, 0x52, 0x74, 0x26, - 0x09, 0xab, 0x12, 0xd7, 0x26, 0x9d, 0x43, 0xd2, 0x94, 0x95, 0xcc, 0x20, 0x67, 0x60, 0x6a, 0xcf, - 0xb4, 0x54, 0x4c, 0x83, 0x05, 0xd2, 0x12, 0x7b, 0x41, 0x37, 0x60, 0x56, 0x37, 0xd4, 0x56, 0xd7, - 0xd6, 0x9f, 0x60, 0xd9, 0x2d, 0x1a, 0x03, 0x02, 0x33, 0x5e, 0x02, 0x15, 0x68, 0x06, 0x0d, 0xe1, - 0x7e, 0x32, 0x9d, 0x16, 0x33, 0xa5, 0x6f, 0x09, 0x30, 0xe3, 0xb5, 0x5d, 0x94, 0x03, 0x7f, 0xb9, - 0x47, 0xf1, 0x27, 0x6f, 0x3d, 0xa2, 0xec, 0xd2, 0x3f, 0x0a, 0x30, 0x2b, 0x61, 0xd5, 0x7c, 0x42, - 0x1b, 0x33, 0x4a, 0xe3, 0x5a, 0x65, 0xc1, 0x24, 0xf1, 0x53, 0x1a, 0x04, 0x0d, 0x2f, 0xb9, 0x05, - 0x67, 0xf4, 0x36, 0x99, 0x19, 0x74, 0xa7, 0x75, 0xc4, 0x11, 0x8a, 0x83, 0xdd, 0xfd, 0xce, 0x39, - 0x3f, 0xad, 0xec, 0x26, 0xf1, 0xc1, 0x92, 0xed, 0x80, 0xf8, 0xd5, 0x8a, 0x52, 0xef, 0x35, 0xc8, - 0x5b, 0x4c, 0x34, 0xd6, 0x4e, 0xac, 0xfa, 0x9c, 0xc7, 0x4a, 0xb4, 0xff, 0x9d, 0x38, 0xcc, 0xbc, - 0xd5, 0xc5, 0xd6, 0xd1, 0x27, 0x50, 0xf7, 0x57, 0x61, 0xe6, 0x40, 0xd1, 0x1d, 0x79, 0xcf, 0xb4, - 0xe4, 0x6e, 0x47, 0x53, 0x1c, 0x37, 0xec, 0x21, 0x4f, 0xc8, 0x77, 0x4d, 0x6b, 0x87, 0x12, 0x11, - 0x06, 0xf4, 0xd8, 0x30, 0x0f, 0x0c, 0x99, 0x90, 0x29, 0x40, 0x3c, 0x34, 0xf8, 0xe2, 0xee, 0xea, - 0x67, 0xfe, 0xf9, 0x78, 0xf1, 0xce, 0x44, 0x81, 0x4c, 0x34, 0x16, 0xac, 0xdb, 0xd5, 0xb5, 0xe5, - 0x9d, 0x9d, 0xda, 0x9a, 0x24, 0x52, 0x91, 0x6f, 0x33, 0x89, 0x8d, 0x43, 0xc3, 0x75, 0x00, 0x3e, - 0x12, 0x40, 0xf4, 0x15, 0x16, 0x65, 0xab, 0x56, 0x20, 0xfb, 0x5e, 0x17, 0x5b, 0xfa, 0x29, 0xda, - 0x14, 0x38, 0x23, 0x19, 0xbc, 0xde, 0x81, 0x5c, 0x8f, 0x1e, 0x12, 0xbf, 0x98, 0x1e, 0xb2, 0x07, - 0xbe, 0x0a, 0x4a, 0x3f, 0x10, 0x00, 0xd1, 0xca, 0xd7, 0xd8, 0xba, 0xfa, 0x27, 0xcc, 0x60, 0xae, - 0x83, 0x48, 0x43, 0x0b, 0x65, 0x7d, 0x4f, 0x6e, 0xeb, 0xb6, 0xad, 0x1b, 0x4d, 0x6e, 0x31, 0x05, - 0x4a, 0xaf, 0xed, 0x6d, 0x30, 0x2a, 0x6f, 0xcb, 0x5f, 0x83, 0xb9, 0x9e, 0xda, 0x44, 0xd9, 0x9a, - 0x17, 0x21, 0xb7, 0x67, 0x76, 0x0d, 0x4d, 0x66, 0x0b, 0x44, 0x7c, 0x21, 0x2c, 0x4b, 0x69, 0xec, - 0x7b, 0xa5, 0xaf, 0xc6, 0xe1, 0x8c, 0x84, 0x6d, 0xb3, 0xf5, 0x04, 0x47, 0xaf, 0xcf, 0x2d, 0xe0, - 0x9b, 0x1f, 0xf2, 0x2f, 0xa2, 0xd6, 0x0c, 0x93, 0xc1, 0x26, 0xc5, 0xde, 0xf5, 0xf2, 0xcb, 0xa3, - 0x2d, 0x73, 0x70, 0x85, 0x9c, 0xaf, 0x5f, 0x25, 0x83, 0xeb, 0x57, 0xbc, 0x21, 0x7e, 0x05, 0xce, - 0xf6, 0x29, 0x22, 0x4a, 0xdf, 0xe5, 0x47, 0x71, 0xb8, 0xd0, 0x2b, 0x3e, 0x6a, 0x84, 0xf1, 0x7f, - 0x43, 0xd9, 0xa8, 0x0a, 0xf9, 0xb6, 0x6e, 0x9c, 0x6e, 0xfd, 0x2c, 0x47, 0x30, 0x7e, 0xaf, 0xcf, - 0x49, 0xc0, 0x50, 0x98, 0x5e, 0xa3, 0x6c, 0xbb, 0x6f, 0x08, 0x90, 0x8b, 0x7a, 0x85, 0xe6, 0x74, - 0xb1, 0x4e, 0xbc, 0xce, 0x0d, 0xc8, 0x7f, 0x0c, 0x4b, 0x3a, 0x7f, 0x24, 0x00, 0x6a, 0x58, 0x5d, - 0x83, 0x40, 0xca, 0x07, 0x66, 0x33, 0xca, 0xca, 0x9e, 0x81, 0x29, 0xdd, 0xd0, 0xf0, 0x21, 0xad, - 0x6c, 0x52, 0x62, 0x2f, 0x3d, 0xbb, 0x69, 0x89, 0x89, 0x76, 0xd3, 0xfc, 0x90, 0x89, 0x9e, 0x82, - 0x46, 0xa9, 0x85, 0xef, 0xc4, 0x61, 0x8e, 0x57, 0x27, 0xf2, 0x25, 0xad, 0x53, 0x05, 0x5a, 0xa3, - 0xcf, 0x01, 0x74, 0x2c, 0xfc, 0x44, 0x66, 0xac, 0x89, 0x89, 0x58, 0x33, 0x84, 0x83, 0x12, 0xd0, - 0x17, 0x61, 0x86, 0x74, 0xb8, 0x8e, 0x65, 0x76, 0x4c, 0x9b, 0xcc, 0xeb, 0xf6, 0x64, 0x80, 0x62, - 0xf6, 0xd9, 0xf1, 0x62, 0x7e, 0x43, 0x37, 0xb6, 0x39, 0x63, 0xa3, 0x2e, 0x91, 0x9e, 0xeb, 0xbd, - 0xba, 0xce, 0xc8, 0x0f, 0x05, 0x38, 0xf3, 0xb1, 0x2d, 0x02, 0xfe, 0x6f, 0x68, 0xcc, 0x9b, 0x0f, - 0x44, 0xfa, 0x5a, 0x33, 0xf6, 0xcc, 0xe8, 0x97, 0x66, 0xbf, 0x21, 0xc0, 0x6c, 0x40, 0x7c, 0x94, - 0xb3, 0xfe, 0xe9, 0xc2, 0xf9, 0xbf, 0x44, 0xfc, 0x80, 0xa0, 0xd9, 0x47, 0xd9, 0xa9, 0xfe, 0x53, - 0x80, 0x73, 0x65, 0xb6, 0xcf, 0xea, 0x86, 0x0e, 0x44, 0x69, 0x25, 0x45, 0x98, 0x7e, 0x82, 0x2d, - 0x5b, 0x37, 0xd9, 0xbc, 0x97, 0x97, 0xdc, 0x57, 0x34, 0x0f, 0x69, 0xdb, 0x50, 0x3a, 0xf6, 0xbe, - 0xe9, 0xee, 0xe9, 0x78, 0xef, 0x5e, 0x98, 0xc3, 0xd4, 0xe9, 0xc3, 0x1c, 0x52, 0xe1, 0x61, 0x0e, - 0x7c, 0xdb, 0xe3, 0xfb, 0x02, 0x9c, 0x1f, 0xa8, 0x75, 0x94, 0x2d, 0xfd, 0x15, 0xc8, 0xaa, 0x5c, - 0x30, 0x19, 0x43, 0xd9, 0xce, 0x4e, 0x8d, 0x64, 0x3b, 0xa5, 0xa7, 0xfd, 0xec, 0x78, 0x11, 0xdc, - 0xa2, 0xd6, 0xd6, 0x78, 0xc5, 0xc8, 0xb3, 0x56, 0xfa, 0x29, 0x40, 0xbe, 0x72, 0xd8, 0x31, 0x2d, - 0xa7, 0xce, 0x1c, 0x09, 0xb4, 0x06, 0xe9, 0x8e, 0x65, 0x3e, 0xd1, 0xdd, 0x4a, 0x14, 0x42, 0xb7, - 0x3f, 0x7b, 0x78, 0xb6, 0x79, 0x7e, 0xc9, 0xe3, 0x44, 0x12, 0x64, 0x1e, 0x98, 0xaa, 0xd2, 0xba, - 0xab, 0xb7, 0x5c, 0x8b, 0x5d, 0x1e, 0x27, 0x66, 0xd9, 0xe3, 0xd8, 0x56, 0x9c, 0x7d, 0xb7, 0x03, - 0x7b, 0x44, 0x74, 0x0f, 0xd2, 0x55, 0xc7, 0xe9, 0x90, 0x44, 0xde, 0xfb, 0xaf, 0x8c, 0x15, 0x49, - 0x18, 0xb8, 0x24, 0x8f, 0x19, 0x49, 0x30, 0x7b, 0xcf, 0x34, 0x9b, 0x2d, 0x5c, 0x6e, 0x99, 0x5d, - 0xad, 0x6c, 0x1a, 0x7b, 0x7a, 0x93, 0x8f, 0x9e, 0x97, 0xc7, 0x4a, 0xbc, 0x57, 0xae, 0x4b, 0x83, - 0xec, 0xe8, 0xf3, 0x90, 0xae, 0xdf, 0xe1, 0xa2, 0x98, 0xef, 0x73, 0x69, 0xac, 0xa8, 0xfa, 0x1d, - 0xc9, 0x63, 0x42, 0x55, 0xc8, 0xae, 0x3c, 0xed, 0x5a, 0x98, 0xcb, 0x48, 0x51, 0x19, 0x57, 0xc7, - 0xca, 0xa0, 0x3c, 0x52, 0x90, 0x15, 0xbd, 0x05, 0x85, 0xb7, 0x4d, 0xeb, 0x71, 0xcb, 0x54, 0xdc, - 0xba, 0x4d, 0x53, 0x61, 0x2f, 0x8e, 0x15, 0xe6, 0xb2, 0x49, 0x7d, 0x02, 0xe6, 0xbf, 0x08, 0xf9, - 0x9e, 0xc6, 0x41, 0x08, 0x92, 0x1d, 0xd2, 0x0e, 0x02, 0x0d, 0x4a, 0xa1, 0xcf, 0xe8, 0x15, 0x98, - 0x36, 0x4c, 0x0d, 0xbb, 0x36, 0x9b, 0x5f, 0x3d, 0xf3, 0xec, 0x78, 0x31, 0xb5, 0x69, 0x6a, 0x6c, - 0xda, 0xe7, 0x4f, 0x52, 0x8a, 0x64, 0x72, 0x27, 0xfd, 0xf9, 0xab, 0x90, 0x24, 0xed, 0x42, 0x3a, - 0xfb, 0xae, 0x62, 0xe3, 0x1d, 0x4b, 0xe7, 0x32, 0xdd, 0x57, 0x9e, 0xef, 0xef, 0x04, 0x88, 0xd7, - 0xef, 0x10, 0xff, 0x73, 0xb7, 0xab, 0x3e, 0xc6, 0x0e, 0xcf, 0xc5, 0xdf, 0xa8, 0x5f, 0x6a, 0xe1, - 0x3d, 0x9d, 0xf9, 0x22, 0x19, 0x89, 0xbf, 0xa1, 0x17, 0x00, 0x14, 0x55, 0xc5, 0xb6, 0x2d, 0xbb, - 0x67, 0x98, 0x32, 0x52, 0x86, 0x51, 0xd6, 0xf1, 0x11, 0x61, 0xb3, 0xb1, 0x6a, 0x61, 0xc7, 0x8d, - 0xae, 0x61, 0x6f, 0x84, 0xcd, 0xc1, 0xed, 0x8e, 0xec, 0x98, 0x8f, 0xb1, 0x41, 0xdb, 0x33, 0x23, - 0x65, 0x08, 0xa5, 0x41, 0x08, 0x64, 0xfc, 0xc1, 0x86, 0xe6, 0x0f, 0x16, 0x19, 0xc9, 0x7b, 0x27, - 0x22, 0x2d, 0xdc, 0xd4, 0xf9, 0xa1, 0x9c, 0x8c, 0xc4, 0xdf, 0x78, 0x35, 0xbe, 0x29, 0x40, 0xe2, - 0x5e, 0xb9, 0x7e, 0xe2, 0x7a, 0x20, 0x48, 0x2a, 0x5d, 0x6e, 0xf7, 0x19, 0x89, 0x3e, 0xd3, 0xb0, - 0x33, 0xbd, 0xd5, 0x22, 0x70, 0xbc, 0x63, 0x99, 0x5f, 0xc1, 0xaa, 0x5b, 0x8b, 0x02, 0x27, 0x6f, - 0x33, 0x2a, 0x5a, 0x82, 0xac, 0x6a, 0x61, 0x0d, 0x1b, 0x8e, 0xae, 0xb4, 0x6c, 0x5e, 0x9d, 0x20, - 0x89, 0x17, 0xee, 0xab, 0x02, 0x4c, 0x51, 0x43, 0x42, 0xcf, 0x43, 0x46, 0x35, 0x0d, 0x47, 0xd1, - 0x0d, 0x3e, 0x0a, 0x64, 0x24, 0x9f, 0x30, 0xb4, 0x90, 0x17, 0x21, 0xa7, 0xa8, 0xaa, 0xd9, 0x35, - 0x1c, 0xd9, 0x50, 0xda, 0x98, 0x17, 0x36, 0xcb, 0x69, 0x9b, 0x4a, 0x1b, 0xa3, 0x45, 0x70, 0x5f, - 0xbd, 0x53, 0x63, 0x19, 0x09, 0x38, 0x69, 0x1d, 0x1f, 0xf1, 0x92, 0x7c, 0x5f, 0x80, 0xb4, 0x6b, - 0x82, 0xa4, 0x30, 0x4d, 0x6c, 0x60, 0x4b, 0x71, 0x4c, 0xaf, 0x30, 0x1e, 0xa1, 0x7f, 0x96, 0xc8, - 0xf8, 0xb3, 0xc4, 0x19, 0x98, 0x72, 0x94, 0xdd, 0x96, 0x5b, 0x0e, 0xf6, 0x42, 0x97, 0x41, 0x5b, - 0x4a, 0x93, 0xad, 0xe2, 0x64, 0x24, 0xf6, 0x42, 0xaa, 0xc4, 0xe3, 0x1c, 0x99, 0x76, 0xf8, 0x1b, - 0x29, 0x2f, 0x0b, 0xed, 0xdb, 0xc5, 0x4d, 0xdd, 0xa0, 0x8d, 0x9d, 0x90, 0x80, 0x92, 0x68, 0x14, - 0x0d, 0x7a, 0x0e, 0x32, 0x2c, 0x03, 0x36, 0x34, 0xda, 0xe2, 0x09, 0x29, 0x4d, 0x09, 0x15, 0xf7, - 0x98, 0x0c, 0x77, 0x0d, 0xfe, 0x54, 0x80, 0x59, 0x16, 0x1b, 0xc1, 0x62, 0x02, 0xa3, 0x9b, 0x27, - 0x5f, 0x87, 0x8c, 0xa6, 0x38, 0x0a, 0x3b, 0xa5, 0x16, 0x1f, 0x79, 0x4a, 0xcd, 0x1d, 0x0a, 0x49, - 0x7e, 0x7a, 0x52, 0x0d, 0x41, 0x92, 0x3c, 0xb3, 0xd3, 0x7d, 0x12, 0x7d, 0xf6, 0x77, 0x99, 0x83, - 0xc5, 0x8d, 0xd2, 0x6f, 0xf8, 0x71, 0xc2, 0x9d, 0x74, 0xa2, 0x54, 0xc3, 0x17, 0x60, 0x9a, 0x83, - 0x61, 0xae, 0x84, 0xa5, 0x71, 0xe3, 0x9d, 0xbb, 0x0f, 0xc7, 0xd9, 0xd0, 0x2a, 0x00, 0x0b, 0xea, - 0xa3, 0x51, 0x12, 0x89, 0x13, 0x6c, 0x99, 0x50, 0x36, 0x42, 0x45, 0x9b, 0x90, 0x6d, 0x3f, 0x51, - 0x55, 0x79, 0x4f, 0x6f, 0x39, 0x3c, 0x80, 0x28, 0x3c, 0x6a, 0x76, 0xe3, 0x61, 0xb9, 0x7c, 0x97, - 0x66, 0x62, 0x71, 0x3c, 0xfe, 0xbb, 0x04, 0x44, 0x02, 0x7b, 0x46, 0x2f, 0x03, 0x3f, 0x53, 0x20, - 0xdb, 0xee, 0x09, 0xa1, 0xd5, 0xfc, 0xb3, 0xe3, 0xc5, 0x8c, 0x44, 0xa9, 0xf5, 0x7a, 0x43, 0xca, - 0xb0, 0x0c, 0x75, 0xdb, 0x41, 0x97, 0x20, 0x6f, 0xb6, 0x75, 0x47, 0x76, 0x67, 0x78, 0xee, 0xca, - 0xe4, 0x08, 0xd1, 0xf5, 0x00, 0x50, 0x03, 0xae, 0x61, 0x83, 0xf4, 0x05, 0x5a, 0x4f, 0x16, 0x2d, - 0x2e, 0xeb, 0x0e, 0xeb, 0x4f, 0xb2, 0xd9, 0x71, 0xf4, 0xb6, 0xfe, 0x94, 0x6e, 0x57, 0xf2, 0xad, - 0x82, 0x4b, 0x2c, 0x3b, 0xa9, 0x1f, 0x8d, 0x1f, 0xaf, 0xf1, 0xbc, 0x5b, 0x81, 0xac, 0xdc, 0x6a, - 0xbe, 0x2e, 0x40, 0x7e, 0xb5, 0xdb, 0x7a, 0xbc, 0xd5, 0xa9, 0x77, 0xdb, 0x6d, 0xc5, 0x3a, 0x22, - 0x1d, 0x84, 0x59, 0xa7, 0xfe, 0x14, 0xb3, 0xe8, 0x4a, 0x6e, 0x7e, 0xfa, 0x53, 0x4c, 0xcc, 0x8f, - 0x07, 0xed, 0x12, 0x3a, 0x8b, 0xc8, 0xbd, 0x04, 0x79, 0x0a, 0x24, 0x65, 0x6c, 0x38, 0x96, 0x8e, - 0xd9, 0x3a, 0x45, 0x42, 0xca, 0x51, 0x62, 0x85, 0xd1, 0xd0, 0x15, 0x28, 0xd8, 0x47, 0xb6, 0x83, - 0xdb, 0x32, 0x3b, 0x5b, 0xcb, 0xd0, 0x4f, 0x42, 0xca, 0x33, 0xaa, 0xc4, 0x88, 0xa5, 0x3f, 0x4b, - 0x40, 0xc1, 0xb5, 0xb4, 0x28, 0x5d, 0xb4, 0x55, 0x98, 0xda, 0xd3, 0x5b, 0xd8, 0xdd, 0xf5, 0x1d, - 0x3e, 0x4d, 0x7b, 0x61, 0x9d, 0x64, 0xe6, 0x74, 0x5d, 0x73, 0xca, 0x1a, 0x85, 0xb5, 0xcd, 0x7f, - 0x28, 0x40, 0x92, 0xfa, 0x46, 0xb7, 0x20, 0x49, 0xbb, 0xbf, 0x30, 0x49, 0xf7, 0xa7, 0x59, 0xbd, - 0x29, 0x3c, 0x1e, 0x98, 0xc2, 0xc9, 0x7c, 0xb8, 0xaf, 0xbc, 0x7a, 0xeb, 0x36, 0xb5, 0xb4, 0x9c, - 0xc4, 0xdf, 0xd0, 0x2a, 0x8d, 0x1b, 0x30, 0x2d, 0x07, 0x6b, 0xdc, 0x33, 0x09, 0xeb, 0x5c, 0x3d, - 0x0d, 0xef, 0x0e, 0x35, 0x2e, 0x1f, 0xba, 0x00, 0x09, 0x62, 0xc2, 0xd3, 0x6c, 0xab, 0xf2, 0xd9, - 0xf1, 0x62, 0x82, 0x18, 0x2f, 0xa1, 0x31, 0xc7, 0xfa, 0x7e, 0x32, 0x9d, 0x14, 0xa7, 0x4a, 0xdf, - 0x4d, 0x42, 0xbe, 0xd6, 0x8e, 0x7a, 0x70, 0x58, 0xe9, 0x6d, 0xb0, 0x30, 0xc7, 0xb1, 0xe7, 0xa3, - 0x21, 0xed, 0xd5, 0x33, 0xcc, 0x26, 0x4e, 0x36, 0xcc, 0xd6, 0x88, 0x53, 0xc0, 0x8f, 0x03, 0x93, - 0xef, 0xbf, 0x34, 0xf6, 0xfb, 0x0d, 0xd2, 0xe3, 0x24, 0xc2, 0xe3, 0xc7, 0x2d, 0xd3, 0xdd, 0xe3, - 0x37, 0xa9, 0xef, 0xc1, 0x8c, 0x26, 0x35, 0xb9, 0xd1, 0x4c, 0x63, 0x43, 0xa3, 0x26, 0x73, 0xc8, - 0x2d, 0xe6, 0x35, 0x48, 0x68, 0xfa, 0x28, 0x95, 0x86, 0x0d, 0x95, 0x84, 0x65, 0x8c, 0xe1, 0x24, - 0x83, 0x86, 0x13, 0x04, 0x4e, 0xf3, 0x5b, 0x00, 0x7e, 0xad, 0xd0, 0x12, 0xa4, 0xcc, 0x96, 0xe6, - 0x86, 0x5c, 0xe7, 0x57, 0x33, 0xcf, 0x8e, 0x17, 0xa7, 0xb6, 0x5a, 0x5a, 0x6d, 0x4d, 0x9a, 0x32, - 0x5b, 0x5a, 0x4d, 0xa3, 0xa7, 0xa8, 0xf1, 0x81, 0xec, 0x05, 0x80, 0xe4, 0xa4, 0x69, 0x03, 0x1f, - 0xf8, 0x21, 0x28, 0x9e, 0x70, 0x62, 0x36, 0x7f, 0x20, 0x40, 0xc1, 0xd5, 0x60, 0xb4, 0x3d, 0x3d, - 0xad, 0xb7, 0xb9, 0xe5, 0x27, 0x4e, 0x66, 0xf9, 0x2e, 0x1f, 0x3f, 0xeb, 0xf5, 0x35, 0x81, 0x07, - 0xb5, 0xd5, 0x55, 0xc5, 0x21, 0xc3, 0x7c, 0x84, 0xe6, 0xfd, 0x22, 0x88, 0x96, 0x62, 0x68, 0x66, - 0x5b, 0x7f, 0x8a, 0xd9, 0xfa, 0x88, 0xcd, 0xb7, 0x05, 0x66, 0x3c, 0x3a, 0x5d, 0x00, 0x70, 0x97, - 0x77, 0xfe, 0x43, 0xe0, 0x01, 0x70, 0x5e, 0x61, 0xa2, 0x54, 0xda, 0x3a, 0xa4, 0xe8, 0xd2, 0x9e, - 0xdb, 0xdd, 0x5e, 0x09, 0x11, 0x12, 0xf6, 0x75, 0x16, 0xcd, 0xe3, 0x19, 0x3c, 0x15, 0x31, 0xff, - 0x05, 0x98, 0xa2, 0xe4, 0x53, 0x8c, 0x71, 0x5c, 0xf3, 0xef, 0xd3, 0x10, 0x4c, 0xad, 0x5e, 0xe7, - 0xe6, 0x17, 0x9d, 0xde, 0x5d, 0xf7, 0x29, 0xee, 0xbb, 0x4f, 0xe8, 0x15, 0x40, 0x9a, 0x6e, 0xb3, - 0x33, 0xbe, 0xf6, 0xbe, 0xa2, 0x99, 0x07, 0xfe, 0x66, 0xd1, 0xac, 0x9b, 0x52, 0x77, 0x13, 0x82, - 0x31, 0x7d, 0x7e, 0x09, 0xa3, 0xf4, 0xb6, 0x3a, 0x50, 0xe0, 0xf1, 0xbe, 0x11, 0xaf, 0xfd, 0xd2, - 0x98, 0x60, 0x6e, 0x66, 0xec, 0xc5, 0x3f, 0x72, 0xeb, 0x7d, 0x31, 0xca, 0x9a, 0x74, 0x61, 0xce, - 0x95, 0x1b, 0xf5, 0x36, 0xcb, 0xa8, 0xea, 0xd0, 0x35, 0xb4, 0xe0, 0x67, 0xa3, 0xac, 0xd3, 0xbf, - 0x09, 0x50, 0xa8, 0x77, 0x77, 0xd9, 0xbd, 0x0b, 0x51, 0x46, 0x1d, 0x66, 0x5a, 0x78, 0xcf, 0x91, - 0x4f, 0x15, 0x3d, 0x97, 0x26, 0xac, 0x84, 0x8a, 0x56, 0x00, 0x2c, 0x1a, 0xff, 0x4d, 0xe5, 0x24, - 0x26, 0x95, 0x23, 0x65, 0x28, 0x57, 0x20, 0x5a, 0xf0, 0xbb, 0x71, 0x98, 0xf1, 0xaa, 0x19, 0xe5, - 0x50, 0xf3, 0xab, 0x40, 0xbd, 0x65, 0xd9, 0x76, 0x14, 0xc7, 0xe6, 0x25, 0x7c, 0xf9, 0x24, 0x87, - 0x31, 0x56, 0x67, 0x89, 0x4c, 0xe2, 0x51, 0x7b, 0x24, 0x29, 0x43, 0x44, 0xd2, 0x47, 0xb4, 0x0c, - 0x73, 0x74, 0x3c, 0x95, 0x95, 0x4e, 0xa7, 0xa5, 0x63, 0x4d, 0x66, 0x3b, 0x1e, 0x49, 0xba, 0xe3, - 0x31, 0x4b, 0x93, 0x56, 0x58, 0x4a, 0x8d, 0xee, 0x7e, 0xdc, 0x85, 0xdc, 0x9e, 0x85, 0xf1, 0x53, - 0x2c, 0x53, 0x2f, 0xed, 0x24, 0xfb, 0x60, 0x59, 0xc6, 0x58, 0x27, 0x7c, 0x7c, 0xe4, 0x7a, 0x17, - 0x66, 0xa9, 0x6a, 0xa3, 0x3e, 0x43, 0xc3, 0x5b, 0xe5, 0xa7, 0x02, 0xa0, 0xa0, 0xfc, 0x8f, 0xaf, - 0x61, 0xe2, 0x91, 0x37, 0xcc, 0xcb, 0x80, 0x58, 0x68, 0x82, 0x2d, 0x77, 0xb0, 0x25, 0xdb, 0x58, - 0x35, 0xf9, 0x65, 0x01, 0x82, 0x24, 0xf2, 0x94, 0x6d, 0x6c, 0xd5, 0x29, 0xbd, 0xf4, 0x5f, 0x17, - 0x20, 0xc7, 0x75, 0xb2, 0x63, 0xe8, 0xa6, 0x81, 0x6e, 0x41, 0xa2, 0xc9, 0x57, 0x5f, 0xb2, 0xa1, - 0xf8, 0xcc, 0xbf, 0xb0, 0xa4, 0x1a, 0x93, 0x48, 0x5e, 0xc2, 0xd2, 0xe9, 0x3a, 0x21, 0xa1, 0x74, - 0x7e, 0xdc, 0x55, 0x90, 0xa5, 0xd3, 0x75, 0x50, 0x1d, 0x66, 0x54, 0xff, 0xc2, 0x06, 0x99, 0xb0, - 0x27, 0x86, 0x1e, 0x29, 0x09, 0xbd, 0xf6, 0xa2, 0x1a, 0x93, 0x0a, 0x6a, 0x4f, 0x02, 0x2a, 0x07, - 0x6f, 0x08, 0x48, 0x0e, 0x5d, 0x6b, 0xec, 0xbf, 0x9d, 0xa0, 0x1a, 0x0b, 0x5c, 0x24, 0x80, 0x5e, - 0x87, 0x94, 0x46, 0x4f, 0x9e, 0x73, 0x0b, 0x0d, 0x33, 0xa2, 0x9e, 0xc3, 0xfe, 0xd5, 0x98, 0xc4, - 0x39, 0xd0, 0x7d, 0xc8, 0xb1, 0x27, 0x76, 0xde, 0x98, 0xbb, 0xa1, 0x57, 0x86, 0x4b, 0x08, 0x8c, - 0xd6, 0xd5, 0x98, 0x94, 0xd5, 0x7c, 0x2a, 0xfa, 0x34, 0x24, 0x6d, 0x55, 0x31, 0xf8, 0x12, 0xe5, - 0xc2, 0x90, 0xe3, 0xa5, 0x3e, 0x33, 0xcd, 0x8d, 0x1e, 0xc1, 0x2c, 0x5d, 0x90, 0x91, 0x1d, 0x7f, - 0xa7, 0x9a, 0x1e, 0x6f, 0xe9, 0xdd, 0x1c, 0xf7, 0xdc, 0xb3, 0xf0, 0x53, 0x55, 0xd5, 0x98, 0x24, - 0xee, 0xf6, 0x25, 0x91, 0x26, 0xa3, 0xfe, 0x75, 0x40, 0x70, 0x66, 0x68, 0x93, 0x85, 0x9e, 0x73, - 0x22, 0x4d, 0x86, 0x7b, 0x12, 0xd0, 0x3d, 0xc8, 0x2a, 0xc4, 0xdf, 0x91, 0xe9, 0x69, 0x83, 0x22, - 0x0c, 0x5d, 0x6b, 0x1e, 0x38, 0x29, 0x52, 0xa5, 0x47, 0xc4, 0x5c, 0xa2, 0x2f, 0xa8, 0x8d, 0xad, - 0x26, 0x2e, 0x66, 0x47, 0x0b, 0x0a, 0x6e, 0x6f, 0x7b, 0x82, 0x28, 0x11, 0x6d, 0x40, 0x7e, 0xdf, - 0x8d, 0xb8, 0xa5, 0xa1, 0x05, 0xb9, 0xa1, 0x0b, 0xce, 0x21, 0x11, 0xc3, 0xd5, 0x98, 0x94, 0xdb, - 0x0f, 0x90, 0xd1, 0x32, 0xc4, 0x9b, 0x6a, 0x31, 0x4f, 0x65, 0x3c, 0x3f, 0x2a, 0x1e, 0xb6, 0x1a, - 0x93, 0xe2, 0x4d, 0x95, 0xa0, 0x18, 0x16, 0x6c, 0x78, 0x68, 0x14, 0x0b, 0x43, 0x07, 0x99, 0xde, - 0xb0, 0xd0, 0x6a, 0x4c, 0xa2, 0xc1, 0x93, 0xe4, 0x7b, 0xdb, 0x50, 0xb0, 0x58, 0x7c, 0x80, 0x1b, - 0x05, 0x23, 0x52, 0x29, 0xd7, 0xc2, 0x87, 0xaa, 0x81, 0x40, 0x98, 0x6a, 0x4c, 0xca, 0x5b, 0x41, - 0x3a, 0xfa, 0x32, 0x9c, 0xe9, 0x95, 0xc8, 0x8d, 0x7b, 0x76, 0x60, 0xe4, 0x0a, 0x97, 0xdb, 0x6b, - 0xe3, 0xc8, 0x1a, 0x48, 0x44, 0x9f, 0x81, 0x29, 0xd6, 0x6a, 0x88, 0x8a, 0x0c, 0xdb, 0x9a, 0xea, - 0x6b, 0x30, 0x96, 0x9f, 0xf4, 0x37, 0x87, 0x6f, 0x8c, 0xcb, 0x2d, 0xb3, 0x59, 0x9c, 0x1b, 0xda, - 0xdf, 0x06, 0x37, 0xfa, 0x49, 0x7f, 0x73, 0x7c, 0x2a, 0x69, 0x77, 0x8b, 0xa5, 0xf0, 0x7d, 0xd4, - 0x33, 0x43, 0xdb, 0x3d, 0x64, 0xbf, 0xbc, 0x4a, 0x83, 0xfc, 0x7c, 0x32, 0x29, 0x9a, 0xc5, 0x4e, - 0x74, 0xcb, 0xb4, 0x1b, 0x9f, 0x1d, 0x5a, 0xb4, 0xc1, 0x53, 0xea, 0xa4, 0x68, 0x96, 0x4f, 0x45, - 0x0f, 0x41, 0xe4, 0xa7, 0x36, 0xfd, 0xf5, 0xab, 0x73, 0x43, 0x77, 0x2e, 0xc2, 0x37, 0x1e, 0xab, - 0x31, 0x69, 0x46, 0xed, 0x4d, 0x21, 0x83, 0x05, 0x95, 0x27, 0xab, 0xfe, 0x71, 0xdb, 0x62, 0x71, - 0xe8, 0x60, 0x31, 0xe4, 0x80, 0x36, 0x19, 0x2c, 0xd4, 0xbe, 0x24, 0x62, 0xc6, 0xba, 0xa1, 0x3b, - 0x74, 0x60, 0x9f, 0x1f, 0x6a, 0xc6, 0xbd, 0x77, 0xea, 0x10, 0x33, 0xd6, 0x19, 0x85, 0x98, 0xb1, - 0xc3, 0x37, 0xd9, 0x79, 0x73, 0x3c, 0x3f, 0xd4, 0x8c, 0xc3, 0x76, 0xe3, 0x89, 0x19, 0x3b, 0x41, - 0x3a, 0x31, 0x63, 0x36, 0x40, 0xf4, 0xc9, 0x7d, 0x61, 0xa8, 0x19, 0x0f, 0x3d, 0xef, 0x43, 0xcc, - 0x58, 0x19, 0x48, 0x44, 0x6b, 0x00, 0xcc, 0x23, 0xd2, 0x8d, 0x3d, 0xb3, 0xb8, 0x30, 0x74, 0xfe, - 0xe9, 0xdf, 0x66, 0x27, 0xf3, 0x4f, 0xcb, 0xa5, 0x91, 0x81, 0x8c, 0xfa, 0xd8, 0x32, 0x5d, 0x2c, - 0x2f, 0x2e, 0x0e, 0x1d, 0xc8, 0x06, 0xd6, 0xcc, 0xc9, 0x40, 0x76, 0xe0, 0x11, 0xc9, 0x44, 0xc6, - 0x96, 0x98, 0x8a, 0x4b, 0x63, 0x96, 0x32, 0x02, 0x13, 0x19, 0xe3, 0x40, 0x2b, 0x90, 0x21, 0x9e, - 0xc2, 0x11, 0x1d, 0x86, 0x2e, 0x0e, 0xf5, 0x6e, 0xfb, 0xa2, 0x58, 0xab, 0x31, 0x29, 0xfd, 0x1e, - 0x27, 0x91, 0xcf, 0x33, 0x9c, 0x5f, 0x2c, 0x0d, 0xfd, 0x7c, 0xcf, 0xca, 0x0e, 0xf9, 0x3c, 0xe3, - 0x40, 0x2a, 0x9c, 0x65, 0x6d, 0xc5, 0x0f, 0x08, 0x59, 0xfc, 0x0c, 0x4d, 0xf1, 0x12, 0x15, 0x35, - 0x14, 0x35, 0x87, 0x1e, 0x56, 0xaa, 0xc6, 0xa4, 0x39, 0x65, 0x30, 0x95, 0x74, 0x78, 0x3e, 0xf5, - 0x30, 0xac, 0x5d, 0xbc, 0x3c, 0xb4, 0xc3, 0x87, 0xac, 0x4e, 0x90, 0x0e, 0xaf, 0x04, 0xc8, 0x6c, - 0x02, 0xd2, 0x64, 0xdb, 0x66, 0x5b, 0x2b, 0x57, 0x46, 0x4c, 0x40, 0x7d, 0x80, 0x9b, 0x4d, 0x40, - 0x5a, 0x9d, 0x71, 0x12, 0x41, 0x6a, 0x0b, 0x2b, 0x16, 0x1f, 0x66, 0xaf, 0x0e, 0x15, 0x34, 0x70, - 0x4f, 0x0d, 0x11, 0xa4, 0x7a, 0x44, 0x32, 0x61, 0x5b, 0xee, 0x71, 0x6f, 0xee, 0x6d, 0x5e, 0x1b, - 0x3a, 0x61, 0x87, 0x9e, 0x4a, 0x27, 0x13, 0xb6, 0xd5, 0x93, 0x80, 0x3e, 0x07, 0xd3, 0xfc, 0xec, - 0x6c, 0xf1, 0xfa, 0x08, 0x1f, 0x38, 0x08, 0xab, 0x49, 0xbf, 0xe6, 0x3c, 0x6c, 0x94, 0x65, 0x47, - 0x6f, 0x59, 0xf5, 0x5e, 0x1c, 0x31, 0xca, 0x0e, 0x20, 0x5a, 0x36, 0xca, 0xfa, 0x64, 0x32, 0xca, - 0x32, 0x3b, 0xe5, 0x73, 0xdd, 0x8d, 0xa1, 0xa3, 0xec, 0x60, 0x08, 0x2d, 0x19, 0x65, 0xdf, 0xf3, - 0xa9, 0xa4, 0x66, 0x36, 0x03, 0x62, 0xc5, 0x97, 0x86, 0xd6, 0xac, 0x17, 0x91, 0x92, 0x9a, 0x71, - 0x1e, 0xd2, 0x6c, 0x2c, 0xba, 0x8b, 0x69, 0xfa, 0xe5, 0xa1, 0xcd, 0x36, 0x80, 0x5b, 0xaa, 0xee, - 0x1d, 0x86, 0x4c, 0xc3, 0xde, 0x40, 0x65, 0xf1, 0xf3, 0x4e, 0x5c, 0x53, 0xaf, 0x8c, 0x1e, 0xa8, - 0xc2, 0x8e, 0x72, 0x79, 0x03, 0x55, 0x4f, 0x22, 0x2d, 0x2a, 0x0b, 0x48, 0xa7, 0xfd, 0x7b, 0x79, - 0x78, 0x51, 0xfb, 0xcf, 0x08, 0xd0, 0xa2, 0x7a, 0x44, 0xbf, 0x0b, 0x75, 0xd9, 0x69, 0xd1, 0xe2, - 0xcd, 0xd1, 0x5d, 0xa8, 0xf7, 0xd4, 0xaa, 0xd7, 0x85, 0x38, 0xd9, 0x9b, 0x33, 0x5d, 0x0f, 0xe3, - 0x53, 0xa3, 0xe7, 0xcc, 0x7e, 0xd7, 0x82, 0xcd, 0x99, 0xfc, 0x3a, 0x9f, 0x69, 0x1e, 0x6f, 0x78, - 0x3f, 0x99, 0x9e, 0x11, 0xc5, 0xfb, 0xc9, 0xf4, 0x79, 0xb1, 0x78, 0x3f, 0x99, 0xbe, 0x20, 0xce, - 0xdf, 0x4f, 0xa6, 0x9f, 0x13, 0x9f, 0x2f, 0xfd, 0xe8, 0x02, 0xe4, 0x5d, 0xac, 0xc6, 0x90, 0xcf, - 0xed, 0x20, 0xf2, 0x59, 0x18, 0x86, 0x7c, 0x38, 0xba, 0xe3, 0xd0, 0xe7, 0x76, 0x10, 0xfa, 0x2c, - 0x0c, 0x83, 0x3e, 0x3e, 0x0f, 0xc1, 0x3e, 0x8d, 0x61, 0xd8, 0xe7, 0xc5, 0x09, 0xb0, 0x8f, 0x27, - 0xaa, 0x1f, 0xfc, 0xac, 0x0d, 0x82, 0x9f, 0xcb, 0xa3, 0xc1, 0x8f, 0x27, 0x2a, 0x80, 0x7e, 0xde, - 0xe8, 0x43, 0x3f, 0x17, 0x47, 0xa0, 0x1f, 0x8f, 0xdf, 0x85, 0x3f, 0xeb, 0xa1, 0xf0, 0xe7, 0xea, - 0x38, 0xf8, 0xe3, 0xc9, 0xe9, 0xc1, 0x3f, 0xaf, 0xf6, 0xe0, 0x9f, 0xc5, 0xa1, 0xf8, 0xc7, 0xe3, - 0x66, 0x00, 0xe8, 0x9d, 0xe1, 0x00, 0xe8, 0xa5, 0x89, 0x00, 0x90, 0x27, 0x6f, 0x10, 0x01, 0x35, - 0x86, 0x21, 0xa0, 0x17, 0x27, 0x40, 0x40, 0x7e, 0xc3, 0xf5, 0x41, 0xa0, 0x6a, 0x18, 0x04, 0xba, - 0x32, 0x06, 0x02, 0x79, 0xd2, 0x82, 0x18, 0xa8, 0x1a, 0x86, 0x81, 0xae, 0x8c, 0xc1, 0x40, 0x7d, - 0x92, 0x18, 0x08, 0xda, 0x0c, 0x07, 0x41, 0xd7, 0xc6, 0x82, 0x20, 0x4f, 0x5a, 0x2f, 0x0a, 0xba, - 0x19, 0x40, 0x41, 0x2f, 0x0c, 0x41, 0x41, 0x1e, 0x2b, 0x81, 0x41, 0x9f, 0x1f, 0x80, 0x41, 0xa5, - 0x51, 0x30, 0xc8, 0xe3, 0xf5, 0x70, 0xd0, 0x5b, 0x43, 0x70, 0xd0, 0xf5, 0xf1, 0x38, 0xc8, 0x13, - 0xd6, 0x07, 0x84, 0x94, 0x91, 0x40, 0xe8, 0x95, 0x09, 0x81, 0x90, 0x27, 0x3d, 0x0c, 0x09, 0xbd, - 0xd6, 0x8b, 0x84, 0x96, 0x86, 0x23, 0x21, 0x4f, 0x0c, 0x87, 0x42, 0xeb, 0xa1, 0x50, 0xe8, 0xea, - 0x38, 0x28, 0xe4, 0xf7, 0xbd, 0x20, 0x16, 0xda, 0x0c, 0xc7, 0x42, 0xd7, 0xc6, 0x62, 0x21, 0xbf, - 0xf9, 0x7b, 0xc0, 0xd0, 0x7a, 0x28, 0x18, 0xba, 0x3a, 0x0e, 0x0c, 0xf9, 0x85, 0x0b, 0xa2, 0xa1, - 0xb7, 0x87, 0xa2, 0xa1, 0x1b, 0x93, 0xa0, 0x21, 0x4f, 0xe8, 0x00, 0x1c, 0x7a, 0x67, 0x38, 0x1c, - 0x7a, 0xe9, 0x04, 0x17, 0x15, 0x85, 0xe2, 0xa1, 0xcf, 0x0f, 0xe0, 0xa1, 0xd2, 0x28, 0x3c, 0xe4, - 0xdb, 0xb3, 0x0b, 0x88, 0x94, 0x91, 0xf0, 0xe5, 0x95, 0x09, 0xe1, 0x8b, 0x6f, 0x7c, 0x21, 0xf8, - 0xa5, 0x12, 0x82, 0x5f, 0x2e, 0x8f, 0xc6, 0x2f, 0xfe, 0x14, 0xe2, 0x03, 0x98, 0x6a, 0x18, 0x80, - 0xb9, 0x32, 0x06, 0xc0, 0xf8, 0xa3, 0x50, 0x00, 0xc1, 0xbc, 0xd1, 0x87, 0x60, 0x2e, 0x8e, 0x8d, - 0x26, 0x08, 0x40, 0x98, 0xd5, 0x41, 0x08, 0x73, 0x69, 0x24, 0x84, 0xf1, 0x24, 0xf8, 0x18, 0xe6, - 0x8d, 0x3e, 0x0c, 0x73, 0x71, 0x04, 0x86, 0xf1, 0x0b, 0xc0, 0x41, 0x8c, 0x36, 0x1a, 0xc4, 0x2c, - 0x4f, 0x0a, 0x62, 0x3c, 0xc1, 0xa1, 0x28, 0x66, 0x33, 0x1c, 0xc5, 0x5c, 0x9b, 0x70, 0x63, 0x71, - 0x00, 0xc6, 0x54, 0xc3, 0x60, 0xcc, 0x95, 0x31, 0x30, 0x26, 0x38, 0x87, 0x78, 0x38, 0xa6, 0x1a, - 0x86, 0x63, 0xae, 0x8c, 0xc1, 0x31, 0xbe, 0xa4, 0x00, 0x90, 0x69, 0x0c, 0x03, 0x32, 0x2f, 0x4e, - 0x00, 0x64, 0xfc, 0x79, 0xb7, 0x0f, 0xc9, 0xbc, 0xd9, 0x8f, 0x64, 0x4a, 0xa3, 0x90, 0x8c, 0xdf, - 0x23, 0x5d, 0x28, 0xb3, 0x19, 0x0e, 0x65, 0xae, 0x8d, 0x85, 0x32, 0xc1, 0x41, 0x32, 0x80, 0x65, - 0xd6, 0x43, 0xb1, 0xcc, 0xd5, 0x71, 0x58, 0xc6, 0x1f, 0x24, 0x83, 0x60, 0xe6, 0xcd, 0x7e, 0x30, - 0x53, 0x1a, 0x05, 0x66, 0xfc, 0xca, 0xb9, 0x68, 0xa6, 0x1a, 0x86, 0x66, 0xae, 0x8c, 0x41, 0x33, - 0x7e, 0xe3, 0x05, 0xe0, 0x8c, 0x32, 0x12, 0xce, 0xbc, 0x32, 0x21, 0x9c, 0xe9, 0x1b, 0xb8, 0x7a, - 0xf1, 0x4c, 0x35, 0x0c, 0xcf, 0x5c, 0x19, 0x83, 0x67, 0x02, 0x85, 0xf5, 0x01, 0xcd, 0x66, 0x38, - 0xa0, 0xb9, 0x36, 0x16, 0xd0, 0xf4, 0xf5, 0x26, 0x17, 0xd1, 0xac, 0x87, 0x22, 0x9a, 0xab, 0xe3, - 0x10, 0x4d, 0xdf, 0xc4, 0x37, 0x21, 0xa4, 0xb9, 0x9f, 0x4c, 0x3f, 0x2f, 0xbe, 0x50, 0xfa, 0xf9, - 0x14, 0xa4, 0xaa, 0x6e, 0x70, 0x4f, 0xe0, 0xa6, 0x03, 0xe1, 0x34, 0x37, 0x1d, 0xa0, 0x35, 0xd2, - 0x4b, 0xe8, 0x58, 0xc3, 0x41, 0xce, 0x88, 0x8b, 0x3c, 0x06, 0x6f, 0x46, 0xe1, 0xac, 0xa7, 0x38, - 0xfa, 0x84, 0x5e, 0x85, 0x7c, 0xd7, 0xc6, 0x96, 0xdc, 0xb1, 0x74, 0xd3, 0xd2, 0x1d, 0x16, 0x12, - 0x2b, 0xac, 0x8a, 0x1f, 0x1d, 0x2f, 0xe6, 0x76, 0x6c, 0x6c, 0x6d, 0x73, 0xba, 0x94, 0xeb, 0x06, - 0xde, 0xdc, 0x7f, 0x33, 0x98, 0x9a, 0xfc, 0xdf, 0x0c, 0xde, 0x02, 0xd1, 0xc2, 0x8a, 0xd6, 0x33, - 0xeb, 0xb3, 0x2b, 0x04, 0xc2, 0xdb, 0x89, 0xc6, 0x7e, 0xbb, 0x39, 0xe9, 0x55, 0x02, 0x33, 0x56, - 0x2f, 0x11, 0xdd, 0x82, 0xb3, 0x6d, 0xe5, 0x90, 0x06, 0x44, 0xc9, 0xae, 0x23, 0x45, 0x83, 0x9c, - 0xd2, 0x34, 0x16, 0x0f, 0xb5, 0x95, 0x43, 0xfa, 0xd7, 0x08, 0x2c, 0x89, 0x5e, 0x8a, 0x7c, 0x05, - 0x0a, 0x9a, 0x6e, 0x3b, 0xba, 0xa1, 0xba, 0x77, 0xa1, 0xb1, 0xbb, 0x06, 0xf2, 0x2e, 0x95, 0xdd, - 0x49, 0x76, 0x03, 0x66, 0x79, 0xd4, 0xa3, 0xff, 0x67, 0x09, 0x14, 0x32, 0xa4, 0x49, 0x29, 0x48, - 0x82, 0xff, 0x2f, 0x19, 0x65, 0x98, 0x69, 0x2a, 0x0e, 0x3e, 0x50, 0x8e, 0x64, 0x37, 0xfc, 0x3c, - 0x4b, 0xaf, 0x16, 0x7a, 0xee, 0xd9, 0xf1, 0x62, 0xfe, 0x1e, 0x4b, 0x1a, 0x88, 0x42, 0xcf, 0x37, - 0x03, 0x09, 0x1a, 0x5a, 0x81, 0x1c, 0xbd, 0xec, 0xd4, 0x64, 0x77, 0xea, 0x72, 0x20, 0x30, 0x6c, - 0x3b, 0x8a, 0xdf, 0xbc, 0x2b, 0xd1, 0x0b, 0x52, 0xdd, 0x6b, 0x78, 0xaf, 0xc1, 0x8c, 0x62, 0x1f, - 0x19, 0x2a, 0xd5, 0x30, 0x36, 0xec, 0xae, 0x4d, 0x91, 0x40, 0x5a, 0x2a, 0x50, 0x72, 0xd9, 0xa5, - 0xa2, 0xd7, 0xe0, 0x82, 0x86, 0x89, 0x6b, 0xc3, 0xfc, 0x07, 0xc7, 0x34, 0x65, 0xb3, 0xa5, 0xc9, - 0xf4, 0x1c, 0x31, 0x45, 0x01, 0x69, 0xe9, 0x2c, 0xcd, 0x40, 0x3d, 0x87, 0x86, 0x69, 0x6e, 0xb5, - 0xb4, 0x0a, 0x49, 0xe4, 0x37, 0xa7, 0xfd, 0xb6, 0x00, 0xb9, 0x9e, 0x20, 0xe2, 0x37, 0xfa, 0xf6, - 0x6b, 0x2f, 0x84, 0xe3, 0x97, 0x61, 0x91, 0x71, 0x69, 0xde, 0x76, 0x6e, 0xb4, 0xce, 0xe2, 0x70, - 0xff, 0x97, 0xae, 0x20, 0xb8, 0x51, 0x02, 0x2e, 0xdb, 0xeb, 0xc9, 0xdf, 0x7d, 0x7f, 0x31, 0x56, - 0xfa, 0x59, 0x02, 0xf2, 0xbd, 0xc1, 0xc2, 0xb5, 0xbe, 0x72, 0x85, 0x8d, 0x2f, 0x3d, 0x1c, 0xcb, - 0x23, 0x2e, 0xda, 0xc9, 0xf8, 0x97, 0xab, 0xb2, 0x62, 0x2e, 0x8d, 0xd8, 0x95, 0x0e, 0x96, 0xd3, - 0x67, 0x9c, 0xff, 0x5e, 0xdc, 0x1b, 0x33, 0x96, 0x61, 0x8a, 0x29, 0x5c, 0x18, 0x7a, 0x9c, 0x8a, - 0xea, 0x5c, 0x62, 0xd9, 0xc8, 0x18, 0xd3, 0x38, 0xd5, 0x6d, 0x2a, 0x1e, 0xe1, 0x14, 0xff, 0x40, - 0xc2, 0xef, 0xd4, 0x99, 0x3a, 0xd9, 0x9d, 0x3a, 0x6c, 0xd7, 0xb9, 0xd5, 0xc2, 0xaa, 0xc3, 0xff, - 0x72, 0xc6, 0xfd, 0x9f, 0x91, 0xcb, 0xfd, 0x22, 0xf8, 0x1f, 0xd4, 0x2c, 0x4b, 0xfc, 0x0f, 0x6a, - 0x02, 0x01, 0x54, 0x05, 0x4f, 0x04, 0xed, 0x92, 0x2c, 0xcc, 0x8e, 0x37, 0xf5, 0x6f, 0x08, 0x20, - 0xd2, 0x0e, 0x78, 0x17, 0x63, 0x2d, 0x12, 0x2b, 0x74, 0x63, 0xbb, 0xe2, 0x13, 0xc7, 0x76, 0x95, - 0x14, 0x28, 0x78, 0x65, 0x60, 0x7f, 0xb8, 0x30, 0xe2, 0x32, 0x9c, 0x53, 0x9d, 0xcb, 0x2d, 0xfd, - 0x9e, 0x00, 0x73, 0xde, 0x37, 0xca, 0xde, 0x71, 0xb0, 0xd3, 0x44, 0xdb, 0x4a, 0xf4, 0xcf, 0x64, - 0x08, 0x10, 0xa6, 0x67, 0x35, 0x27, 0xb2, 0x20, 0xc4, 0x03, 0x20, 0x80, 0x03, 0x6c, 0xad, 0x51, - 0xa7, 0x7f, 0x33, 0xc3, 0x9e, 0xed, 0xd2, 0xdd, 0x80, 0x06, 0xa8, 0xb1, 0x92, 0x6a, 0x4e, 0x64, - 0xd5, 0x6e, 0x35, 0x69, 0xe6, 0xd2, 0x0f, 0x84, 0xa0, 0xa0, 0x27, 0xc4, 0xb1, 0xba, 0x03, 0x89, - 0x27, 0x4a, 0x6b, 0x54, 0xfc, 0x47, 0x8f, 0xea, 0x25, 0x92, 0x1b, 0xdd, 0xed, 0x39, 0x45, 0x17, - 0x1f, 0xee, 0x04, 0x0c, 0xaa, 0x34, 0x78, 0xda, 0x0e, 0x7d, 0xc6, 0xad, 0x45, 0x62, 0xfc, 0xe7, - 0x83, 0x9d, 0xf4, 0xf5, 0xe4, 0x07, 0xef, 0x2f, 0x0a, 0x37, 0xea, 0x30, 0x17, 0x32, 0x7d, 0xa1, - 0x02, 0x40, 0xe0, 0xbe, 0x5b, 0xfe, 0x5f, 0x36, 0x2b, 0x6b, 0xf2, 0xce, 0x66, 0x79, 0x6b, 0x63, - 0xa3, 0xd6, 0x68, 0x54, 0xd6, 0x44, 0x01, 0x89, 0x90, 0xeb, 0xb9, 0x2d, 0x97, 0xff, 0x85, 0xcd, - 0x8d, 0x5f, 0x02, 0xf0, 0xef, 0xb9, 0x26, 0xb2, 0xd6, 0x2b, 0x8f, 0xe4, 0x87, 0x2b, 0x0f, 0x76, - 0x2a, 0x75, 0x31, 0x86, 0x10, 0x14, 0x56, 0x57, 0x1a, 0xe5, 0xaa, 0x2c, 0x55, 0xea, 0xdb, 0x5b, - 0x9b, 0xf5, 0x8a, 0x28, 0x70, 0xbe, 0x35, 0xc8, 0x05, 0xcf, 0x1b, 0xa2, 0x39, 0x98, 0x29, 0x57, - 0x2b, 0xe5, 0x75, 0xf9, 0x61, 0x6d, 0x45, 0x7e, 0x6b, 0xa7, 0xb2, 0x53, 0x11, 0x63, 0xb4, 0x68, - 0x94, 0x78, 0x77, 0xe7, 0xc1, 0x03, 0x51, 0x40, 0x33, 0x90, 0x65, 0xef, 0xf4, 0x66, 0x5d, 0x31, - 0x7e, 0x63, 0x03, 0xb2, 0x81, 0x4b, 0x7d, 0xc8, 0xe7, 0xb6, 0x77, 0xea, 0x55, 0xb9, 0x51, 0xdb, - 0xa8, 0xd4, 0x1b, 0x2b, 0x1b, 0xdb, 0x4c, 0x06, 0xa5, 0xad, 0xac, 0x6e, 0x49, 0x0d, 0x51, 0xf0, - 0xde, 0x1b, 0x5b, 0x3b, 0xe5, 0xaa, 0xf7, 0x4f, 0x3c, 0xc9, 0x74, 0x42, 0x4c, 0xdc, 0x30, 0xe1, - 0x6c, 0xe8, 0x01, 0x3e, 0x94, 0x85, 0xe9, 0x1d, 0x83, 0x5e, 0x4f, 0x22, 0xc6, 0x50, 0x3e, 0x70, - 0x86, 0x4f, 0x14, 0x50, 0x9a, 0x9d, 0xd4, 0x12, 0xe3, 0x28, 0x05, 0xf1, 0xfa, 0x1d, 0x31, 0x41, - 0x8a, 0x19, 0x38, 0x08, 0x27, 0x26, 0x51, 0x86, 0x9f, 0x1f, 0x12, 0xa7, 0x50, 0xce, 0x3f, 0xc0, - 0x23, 0xa6, 0x6e, 0x5c, 0x84, 0xc0, 0xf9, 0x06, 0x04, 0x90, 0x7a, 0xa0, 0x38, 0xd8, 0x76, 0xc4, - 0x18, 0x9a, 0x86, 0xc4, 0x4a, 0xab, 0x25, 0x0a, 0xb7, 0xff, 0x5c, 0x80, 0xb4, 0x7b, 0xa9, 0x2a, - 0x7a, 0x00, 0x53, 0x0c, 0x1b, 0x2f, 0x0e, 0x9f, 0x32, 0xe8, 0xa8, 0x33, 0xbf, 0x34, 0x6e, 0x4e, - 0x29, 0xc5, 0xd0, 0xdb, 0xfc, 0x4f, 0xb5, 0x88, 0xbd, 0xa0, 0x4b, 0xa3, 0xac, 0xc9, 0x95, 0x3a, - 0xda, 0xe4, 0x48, 0x0f, 0x29, 0xc5, 0x3e, 0x25, 0xac, 0xbe, 0xf8, 0xc1, 0xbf, 0x2e, 0xc4, 0x3e, - 0x78, 0xb6, 0x20, 0x7c, 0xf8, 0x6c, 0x41, 0xf8, 0xf1, 0xb3, 0x05, 0xe1, 0x5f, 0x9e, 0x2d, 0x08, - 0xbf, 0xf5, 0x93, 0x85, 0xd8, 0x87, 0x3f, 0x59, 0x88, 0xfd, 0xf8, 0x27, 0x0b, 0xb1, 0x77, 0xa6, - 0x39, 0xf7, 0x6e, 0x8a, 0xfe, 0xbf, 0xd7, 0x9d, 0xff, 0x09, 0x00, 0x00, 0xff, 0xff, 0x59, 0x76, - 0x7f, 0x95, 0xe4, 0x6c, 0x00, 0x00, +func init() { proto.RegisterFile("roachpb/api.proto", fileDescriptor_api_e552681b39a41c3e) } + +var fileDescriptor_api_e552681b39a41c3e = []byte{ + // 6802 bytes of a gzipped FileDescriptorProto + 0x1f, 0x8b, 0x08, 0x00, 0x00, 0x00, 0x00, 0x00, 0x02, 0xff, 0xe4, 0x7d, 0x5b, 0x6c, 0x23, 0xc9, + 0x75, 0x36, 0x9b, 0xa4, 0x28, 0xf2, 0xf0, 0xa2, 0x56, 0x69, 0x2e, 0x1c, 0xed, 0xae, 0xa4, 0xe1, + 0x5c, 0x77, 0x76, 0x57, 0xe3, 0x99, 0xf1, 0xfe, 0xde, 0x7f, 0xd7, 0x5e, 0x5b, 0xa2, 0x38, 0x43, + 0x8e, 0x46, 0x97, 0x6d, 0x52, 0xb3, 0x9e, 0x75, 0x36, 0xed, 0x56, 0x77, 0x89, 0x6a, 0x0f, 0xd9, + 0xcd, 0xed, 0x6e, 0x8e, 0xa4, 0x01, 0x82, 0x00, 0x79, 0x71, 0x60, 0x18, 0x46, 0x1e, 0x82, 0x20, + 0xb0, 0x13, 0x64, 0x01, 0x07, 0x08, 0x90, 0x20, 0x46, 0x02, 0x18, 0xc8, 0x05, 0x01, 0xfc, 0x90, + 0x3c, 0x6c, 0x0c, 0x3f, 0x2c, 0x82, 0xd8, 0x31, 0xf2, 0x20, 0x24, 0xe3, 0x04, 0x36, 0xf2, 0x1a, + 0x20, 0x06, 0x16, 0x41, 0x10, 0xd4, 0xa5, 0x2f, 0x24, 0x9b, 0x17, 0xc9, 0xbd, 0xc8, 0x06, 0x79, + 0x62, 0xf7, 0xa9, 0x3a, 0xa7, 0xab, 0x4e, 0x9d, 0xaa, 0x3a, 0x5f, 0xd5, 0xa9, 0x22, 0xcc, 0x5a, + 0xa6, 0xa2, 0xee, 0x77, 0x76, 0x6f, 0x2a, 0x1d, 0x7d, 0xb9, 0x63, 0x99, 0x8e, 0x89, 0x66, 0x55, + 0x53, 0x7d, 0x4c, 0xc9, 0xcb, 0x3c, 0x71, 0x1e, 0xb9, 0xb9, 0x34, 0xc5, 0x51, 0x58, 0xb6, 0xf9, + 0x33, 0x2e, 0x0d, 0x5b, 0x96, 0x69, 0xd9, 0x9c, 0x7a, 0xce, 0xa5, 0xb6, 0xb1, 0xa3, 0x04, 0x72, + 0x97, 0x6c, 0xc7, 0xb4, 0x94, 0x26, 0xbe, 0x89, 0x8d, 0xa6, 0x6e, 0xb8, 0x3f, 0x24, 0xdf, 0x13, + 0x55, 0xe5, 0x79, 0x2e, 0x8d, 0xca, 0x73, 0x87, 0x67, 0x2a, 0x76, 0x1d, 0xbd, 0x75, 0x73, 0xbf, + 0xa5, 0xde, 0x74, 0xf4, 0x36, 0xb6, 0x1d, 0xa5, 0xdd, 0xe1, 0x29, 0x4b, 0x34, 0xc5, 0xb1, 0x14, + 0x55, 0x37, 0x9a, 0x37, 0x2d, 0xac, 0x9a, 0x96, 0x86, 0x35, 0xd9, 0xee, 0x28, 0x86, 0x5b, 0xe4, + 0xa6, 0xd9, 0x34, 0xe9, 0xe3, 0x4d, 0xf2, 0xc4, 0xa8, 0xa5, 0x5f, 0x85, 0x8c, 0xa4, 0x18, 0x4d, + 0x5c, 0x33, 0xf6, 0x4c, 0xf4, 0x59, 0x48, 0x6a, 0xd8, 0x56, 0x8b, 0xc2, 0x92, 0x70, 0x3d, 0x7b, + 0xbb, 0xb4, 0x3c, 0xa0, 0x8b, 0x65, 0x9a, 0x77, 0x0d, 0xdb, 0xaa, 0xa5, 0x77, 0x1c, 0xd3, 0x5a, + 0x4d, 0x7e, 0x70, 0xbc, 0x18, 0x93, 0x28, 0x17, 0xfa, 0x34, 0x4c, 0xb5, 0xb0, 0x62, 0xe3, 0x62, + 0x9c, 0xb2, 0x17, 0x43, 0xd8, 0x1f, 0x90, 0x74, 0xce, 0xc4, 0x32, 0x97, 0xfe, 0x5a, 0x80, 0xbc, + 0x84, 0xdf, 0xeb, 0x62, 0xdb, 0xa9, 0x62, 0x45, 0xc3, 0x16, 0xba, 0x00, 0x89, 0xc7, 0xf8, 0xa8, + 0x98, 0x58, 0x12, 0xae, 0xe7, 0x56, 0xa7, 0x3f, 0x3a, 0x5e, 0x4c, 0xac, 0xe3, 0x23, 0x89, 0xd0, + 0xd0, 0x12, 0x4c, 0x63, 0x43, 0x93, 0x49, 0x72, 0xb2, 0x37, 0x39, 0x85, 0x0d, 0x6d, 0x1d, 0x1f, + 0x21, 0x15, 0xd2, 0x36, 0x91, 0x66, 0xa8, 0xb8, 0x38, 0xb5, 0x24, 0x5c, 0x9f, 0x5a, 0xbd, 0xf7, + 0xd1, 0xf1, 0x62, 0xb9, 0xa9, 0x3b, 0xfb, 0xdd, 0xdd, 0x65, 0xd5, 0x6c, 0xdf, 0xf4, 0x4a, 0xa5, + 0xed, 0xfa, 0xcf, 0x37, 0x3b, 0x8f, 0x9b, 0x37, 0x87, 0xb4, 0xc0, 0x72, 0xe3, 0xd0, 0xa8, 0xe3, + 0xf7, 0x24, 0x4f, 0xf0, 0xeb, 0xc9, 0x9f, 0xbd, 0xbf, 0x28, 0xdc, 0x4f, 0xa6, 0x05, 0x31, 0x7e, + 0x3f, 0x99, 0x8e, 0x8b, 0x89, 0xd2, 0xd7, 0x13, 0x50, 0x90, 0xb0, 0xdd, 0x31, 0x0d, 0x1b, 0xf3, + 0x6a, 0x7c, 0x0a, 0x12, 0xce, 0xa1, 0x41, 0xab, 0x91, 0xbd, 0xbd, 0x10, 0xa2, 0x8c, 0x86, 0xa5, + 0x18, 0xb6, 0xa2, 0x3a, 0xba, 0x69, 0x48, 0x24, 0x2b, 0x7a, 0x0d, 0xb2, 0x16, 0xb6, 0xbb, 0x6d, + 0x4c, 0x9b, 0x8d, 0xd6, 0x30, 0x7b, 0xfb, 0x7c, 0x08, 0x67, 0xbd, 0xa3, 0x18, 0x12, 0xb0, 0xbc, + 0xe4, 0x19, 0x5d, 0x80, 0xb4, 0xd1, 0x6d, 0x13, 0xbd, 0xd8, 0xb4, 0xd6, 0x09, 0x69, 0xda, 0xe8, + 0xb6, 0xd7, 0xf1, 0x91, 0x8d, 0xca, 0x90, 0xb5, 0x48, 0xa3, 0xc9, 0xba, 0xb1, 0x67, 0xda, 0xc5, + 0xd4, 0x52, 0xe2, 0x7a, 0xf6, 0xf6, 0xf3, 0xc3, 0x9a, 0x96, 0x98, 0x01, 0x6f, 0x1f, 0xb0, 0x5c, + 0x82, 0x8d, 0xea, 0x90, 0xe7, 0x25, 0xb3, 0xb0, 0x62, 0x9b, 0x46, 0x71, 0x7a, 0x49, 0xb8, 0x5e, + 0xb8, 0xbd, 0x1c, 0x26, 0xa6, 0x47, 0x0b, 0xe4, 0xb5, 0xdb, 0xc6, 0x12, 0xe5, 0x92, 0x72, 0x56, + 0xe0, 0xad, 0xf4, 0x08, 0x72, 0xc1, 0x54, 0x84, 0xa0, 0x20, 0x55, 0xea, 0x3b, 0x1b, 0x15, 0x79, + 0x67, 0x73, 0x7d, 0x73, 0xeb, 0xed, 0x4d, 0x31, 0x86, 0xce, 0x80, 0xc8, 0x69, 0xeb, 0x95, 0x47, + 0xf2, 0x83, 0xda, 0x46, 0xad, 0x21, 0x0a, 0xe8, 0x02, 0x9c, 0xe5, 0x54, 0x69, 0x65, 0xf3, 0x5e, + 0x45, 0x5e, 0xdd, 0xda, 0xd9, 0x5c, 0x5b, 0x91, 0x1e, 0x89, 0xf1, 0xf9, 0xe4, 0xaf, 0x7f, 0x7b, + 0x21, 0x56, 0x7a, 0x08, 0x70, 0x0f, 0x3b, 0xdc, 0xac, 0xd0, 0x2a, 0xa4, 0xf6, 0x69, 0x69, 0xb8, + 0x61, 0x2f, 0x85, 0x16, 0x3b, 0x60, 0x82, 0xab, 0x69, 0xa2, 0x81, 0x0f, 0x8f, 0x17, 0x05, 0x89, + 0x73, 0xb2, 0x26, 0x2f, 0x7d, 0x4f, 0x80, 0x2c, 0x15, 0xcc, 0xea, 0x88, 0xca, 0x7d, 0x92, 0x2f, + 0x8e, 0x55, 0xc8, 0xa0, 0x68, 0xb4, 0x0c, 0x53, 0x4f, 0x94, 0x56, 0x77, 0x54, 0xbf, 0x79, 0x48, + 0xd2, 0x25, 0x96, 0x0d, 0xbd, 0x01, 0x39, 0xdd, 0x70, 0xb0, 0xe1, 0xc8, 0x8c, 0x2d, 0x31, 0x86, + 0x2d, 0xcb, 0x72, 0xd3, 0x97, 0xd2, 0x5f, 0x0a, 0x00, 0xdb, 0xdd, 0x28, 0x55, 0x43, 0xfa, 0xfd, + 0x44, 0xe5, 0x77, 0xfb, 0x3d, 0xab, 0xc5, 0x39, 0x48, 0xe9, 0x46, 0x4b, 0x37, 0x58, 0xf9, 0xd3, + 0x12, 0x7f, 0x43, 0x67, 0x60, 0x6a, 0xb7, 0xa5, 0x1b, 0x1a, 0x35, 0xff, 0xb4, 0xc4, 0x5e, 0xb8, + 0xfa, 0x25, 0xc8, 0xd2, 0xb2, 0x47, 0xa8, 0xfd, 0xd2, 0x37, 0xe3, 0x70, 0xb6, 0x6c, 0x1a, 0x9a, + 0x4e, 0xfa, 0xa1, 0xd2, 0xfa, 0x44, 0xe8, 0xe6, 0x55, 0xc8, 0xe0, 0xc3, 0xce, 0x84, 0xcd, 0x9b, + 0xc6, 0x87, 0x1d, 0xfa, 0x14, 0xae, 0x3a, 0xf4, 0x69, 0x38, 0xaf, 0xb4, 0x5a, 0xe6, 0x81, 0xac, + 0xef, 0xc9, 0x9a, 0x89, 0x6d, 0xd9, 0x30, 0x1d, 0x19, 0x1f, 0xea, 0xb6, 0x43, 0x87, 0x8a, 0xb4, + 0x34, 0x47, 0x93, 0x6b, 0x7b, 0x6b, 0x26, 0xb6, 0x37, 0x4d, 0xa7, 0x42, 0x92, 0xb8, 0xc2, 0xdf, + 0x85, 0x73, 0xfd, 0xba, 0x89, 0x52, 0xf7, 0x7f, 0x27, 0x40, 0xa1, 0x66, 0xe8, 0xce, 0x27, 0x42, + 0xe9, 0x9e, 0xf6, 0x12, 0x41, 0xed, 0xdd, 0x00, 0x71, 0x4f, 0xd1, 0x5b, 0x5b, 0x46, 0xc3, 0x6c, + 0xef, 0xda, 0x8e, 0x69, 0x60, 0x9b, 0xab, 0x77, 0x80, 0xce, 0x75, 0xf6, 0x10, 0x66, 0xbc, 0x3a, + 0x45, 0xa9, 0xac, 0xa7, 0x20, 0xd6, 0x0c, 0xd5, 0xc2, 0x6d, 0x6c, 0x44, 0xaa, 0xad, 0xe7, 0x21, + 0xa3, 0xbb, 0x72, 0xa9, 0xc6, 0x12, 0x92, 0x4f, 0xe0, 0x75, 0xea, 0xc2, 0x6c, 0xe0, 0xdb, 0x51, + 0x0e, 0x7e, 0xcf, 0x41, 0xc6, 0xc0, 0x07, 0xb2, 0xdf, 0x5e, 0x09, 0x29, 0x6d, 0xe0, 0x03, 0x36, + 0x58, 0x3d, 0x82, 0xfc, 0x1a, 0x6e, 0x61, 0x07, 0x47, 0x3f, 0x92, 0xef, 0x40, 0xc1, 0x15, 0x1d, + 0x65, 0x23, 0xfd, 0xae, 0x00, 0x88, 0xcb, 0x25, 0xb3, 0x67, 0x94, 0xed, 0xb4, 0x48, 0xbc, 0x03, + 0xa7, 0x6b, 0x19, 0x6c, 0x9a, 0x67, 0x56, 0x0a, 0x8c, 0x44, 0x67, 0x7a, 0x7f, 0x44, 0x4d, 0x06, + 0x47, 0x54, 0xcf, 0x5b, 0x21, 0x7e, 0xca, 0x01, 0xcc, 0xf5, 0x14, 0x2f, 0xda, 0xa6, 0x4c, 0xd2, + 0x92, 0xc5, 0x97, 0x12, 0x41, 0xcf, 0x8c, 0x12, 0x4b, 0xef, 0xc2, 0x6c, 0xb9, 0x85, 0x15, 0x2b, + 0x6a, 0xb5, 0xf0, 0xe6, 0x7c, 0x04, 0x28, 0x28, 0x3e, 0xca, 0x26, 0xfd, 0x7d, 0x01, 0x90, 0x84, + 0x9f, 0x60, 0xcb, 0x89, 0xbc, 0x49, 0xd7, 0x20, 0xeb, 0x28, 0x56, 0x13, 0x3b, 0x32, 0x71, 0xe7, + 0xf9, 0x70, 0xf5, 0x42, 0x40, 0x10, 0x71, 0xea, 0x97, 0xf7, 0x5b, 0xea, 0x72, 0xc3, 0x75, 0xf7, + 0x5d, 0xe7, 0x8c, 0xf1, 0x11, 0x32, 0xd7, 0xc0, 0x3b, 0x30, 0xd7, 0x53, 0xca, 0x28, 0x55, 0xa0, + 0x43, 0xb6, 0xae, 0x2a, 0xc6, 0x56, 0x87, 0xcc, 0x03, 0x36, 0xba, 0x03, 0xe7, 0x6c, 0xc7, 0xec, + 0xc8, 0x8a, 0x23, 0x33, 0xd7, 0x72, 0xd7, 0xec, 0x1a, 0x9a, 0x62, 0x1d, 0xd1, 0x6f, 0xa4, 0xa5, + 0x39, 0x92, 0xba, 0xc2, 0x0a, 0xb2, 0xca, 0x93, 0x88, 0xf9, 0xb6, 0x75, 0x43, 0x26, 0x1e, 0x60, + 0xcb, 0xb1, 0x79, 0x57, 0x87, 0xb6, 0x6e, 0x48, 0x8c, 0xc2, 0xab, 0xf1, 0x6d, 0x81, 0x7d, 0x2b, + 0x4a, 0x35, 0xbf, 0x09, 0x59, 0x5b, 0x55, 0x0c, 0x79, 0xcf, 0xb4, 0xda, 0x8a, 0x43, 0x7b, 0x47, + 0xa1, 0x47, 0xcd, 0x9e, 0x5f, 0xad, 0x2a, 0xc6, 0x5d, 0x9a, 0x49, 0x02, 0xdb, 0x7b, 0x0e, 0x76, + 0xa0, 0xfb, 0xc9, 0x74, 0x42, 0x4c, 0x96, 0x7e, 0x2e, 0x40, 0x8e, 0x95, 0x32, 0xca, 0x0e, 0xf4, + 0x2a, 0x24, 0x2d, 0xf3, 0x80, 0x75, 0xa0, 0xec, 0xed, 0xe7, 0x42, 0x44, 0xac, 0xe3, 0xa3, 0xe0, + 0xcc, 0x45, 0xb3, 0xa3, 0x55, 0xe0, 0x1e, 0x9e, 0x4c, 0xb9, 0x13, 0x93, 0x72, 0x03, 0xe3, 0x92, + 0x88, 0x8c, 0x6b, 0x30, 0xb3, 0xab, 0x38, 0xea, 0x3e, 0x69, 0x1f, 0x5a, 0x48, 0x32, 0xcb, 0x25, + 0xae, 0xe7, 0xa4, 0x02, 0x25, 0xbb, 0x45, 0xb7, 0x4b, 0x7f, 0xe8, 0xf6, 0x06, 0x1b, 0x7f, 0xf2, + 0x9b, 0xe9, 0xbf, 0x04, 0xde, 0x29, 0xdc, 0xc2, 0xfe, 0x5f, 0x6b, 0xad, 0x1f, 0x0a, 0x70, 0xbe, + 0xbc, 0x8f, 0xd5, 0xc7, 0x65, 0xd3, 0xb0, 0x75, 0xdb, 0xc1, 0x86, 0x7a, 0x14, 0x65, 0x93, 0x3d, + 0x07, 0x99, 0x03, 0xdd, 0xd9, 0x97, 0x35, 0x7d, 0x6f, 0x8f, 0x76, 0xe9, 0xb4, 0x94, 0x26, 0x84, + 0x35, 0x7d, 0x6f, 0x0f, 0xdd, 0x81, 0x64, 0xdb, 0xd4, 0x98, 0x03, 0x5b, 0xb8, 0xbd, 0x18, 0x22, + 0x9e, 0x16, 0xcd, 0xee, 0xb6, 0x37, 0x4c, 0x0d, 0x4b, 0x34, 0x33, 0x5a, 0x00, 0x50, 0x09, 0xb5, + 0x63, 0xea, 0x86, 0xc3, 0x27, 0xb2, 0x00, 0x85, 0x8f, 0x12, 0xdf, 0x48, 0x42, 0x71, 0xb0, 0x5e, + 0x51, 0xb6, 0xee, 0x36, 0xa4, 0xd8, 0x50, 0xc5, 0xdb, 0xf7, 0xf6, 0xb0, 0xe2, 0x87, 0x94, 0x60, + 0x99, 0x0d, 0x69, 0xbc, 0xe1, 0xb8, 0x9c, 0xf9, 0xbf, 0x12, 0x20, 0xc5, 0x12, 0xd0, 0x2d, 0x48, + 0x73, 0x4c, 0xae, 0xd1, 0x32, 0x26, 0x56, 0xcf, 0x3d, 0x3b, 0x5e, 0x9c, 0x66, 0x08, 0x7c, 0xed, + 0x23, 0xff, 0x51, 0x9a, 0x66, 0x20, 0x5c, 0x23, 0x9a, 0xb6, 0x1d, 0xc5, 0x72, 0xe8, 0xda, 0x07, + 0xd1, 0x74, 0x4e, 0x4a, 0x53, 0xc2, 0x3a, 0x3e, 0x42, 0xf7, 0x21, 0x65, 0x3b, 0x8a, 0xd3, 0xb5, + 0xb9, 0xae, 0x4f, 0x54, 0xd8, 0x3a, 0xe5, 0x94, 0xb8, 0x04, 0xe2, 0x45, 0x68, 0xd8, 0x51, 0xf4, + 0x16, 0x55, 0x7e, 0x46, 0xe2, 0x6f, 0xa5, 0x6f, 0x09, 0x90, 0x62, 0x59, 0xd1, 0x79, 0x98, 0x63, + 0xb8, 0xbb, 0xb6, 0xb9, 0x56, 0x69, 0x54, 0xa4, 0x8d, 0xda, 0xe6, 0x4a, 0xa3, 0x22, 0xc6, 0xd0, + 0x39, 0x40, 0x6e, 0x42, 0x79, 0x6b, 0xb3, 0x5e, 0xab, 0x37, 0x2a, 0x9b, 0x04, 0xaf, 0x13, 0x14, + 0x4f, 0xe9, 0x01, 0x6a, 0x1c, 0x5d, 0x86, 0xa5, 0x7e, 0xaa, 0x5c, 0x6f, 0xac, 0x34, 0xea, 0x72, + 0xa5, 0xde, 0xa8, 0x6d, 0xac, 0x34, 0x2a, 0x6b, 0x62, 0x62, 0x44, 0x2e, 0xf2, 0x11, 0x49, 0xaa, + 0x94, 0x1b, 0x62, 0xb2, 0xf4, 0x14, 0xce, 0x4a, 0x58, 0x35, 0xdb, 0x9d, 0xae, 0x83, 0x49, 0x29, + 0xed, 0x28, 0xad, 0xfc, 0x3c, 0x4c, 0x6b, 0xd6, 0x91, 0x6c, 0x75, 0x0d, 0x6e, 0xe3, 0x29, 0xcd, + 0x3a, 0x92, 0xba, 0x06, 0x37, 0xc6, 0x3f, 0x13, 0xe0, 0x5c, 0xff, 0xc7, 0xa3, 0x34, 0xc5, 0x2f, + 0x42, 0x56, 0xd1, 0x34, 0xac, 0xc9, 0x1a, 0x6e, 0x39, 0x0a, 0xf7, 0x12, 0x6e, 0x05, 0x24, 0xf1, + 0x75, 0xab, 0x65, 0xb6, 0x60, 0xb5, 0xec, 0xad, 0x5b, 0x6d, 0x3c, 0x2c, 0x97, 0x69, 0x79, 0xd6, + 0x08, 0xa3, 0x3b, 0x8e, 0x50, 0x59, 0x94, 0x52, 0x52, 0xe1, 0xfc, 0x2a, 0x6e, 0xea, 0x46, 0x70, + 0x25, 0x2a, 0x72, 0xd7, 0x4c, 0x86, 0xe2, 0xe0, 0x47, 0x22, 0x75, 0xd0, 0x92, 0x70, 0xb6, 0x62, + 0x68, 0x1f, 0x4f, 0x25, 0x48, 0x7f, 0x50, 0xcd, 0x76, 0x5b, 0x77, 0xdc, 0xb6, 0x67, 0x6f, 0xe8, + 0xff, 0x43, 0x5a, 0xc3, 0x8a, 0xe6, 0xad, 0x60, 0x8c, 0x73, 0xdc, 0x24, 0x2f, 0x3b, 0xfa, 0x32, + 0x9c, 0x27, 0x83, 0xb9, 0x65, 0x28, 0x2d, 0x99, 0x49, 0x93, 0x1d, 0x4b, 0x6f, 0x36, 0xb1, 0xc5, + 0xd7, 0xfc, 0xae, 0x87, 0x94, 0xb3, 0xc6, 0x39, 0xca, 0x94, 0xa1, 0xc1, 0xf2, 0x4b, 0x67, 0xf5, + 0x30, 0x32, 0xfa, 0x82, 0xb7, 0x44, 0x64, 0x77, 0x14, 0xc3, 0x2e, 0x4e, 0xd1, 0x31, 0x6c, 0xd8, + 0x52, 0x22, 0xb7, 0x0c, 0x3e, 0x2f, 0x11, 0x8a, 0x8d, 0x6e, 0x12, 0xb4, 0xf1, 0x5e, 0x57, 0xb7, + 0xb0, 0x7c, 0xab, 0xa3, 0x16, 0x53, 0xa4, 0xee, 0xab, 0x85, 0x67, 0xc7, 0x8b, 0x20, 0x31, 0xf2, + 0xad, 0xed, 0x32, 0x41, 0x1f, 0xec, 0xb9, 0xa3, 0xa2, 0xeb, 0x20, 0x1a, 0xa6, 0x6c, 0xe1, 0x3d, + 0x0b, 0xdb, 0xfb, 0xfc, 0xb3, 0x69, 0xaa, 0xb1, 0x82, 0x61, 0x4a, 0x8c, 0xcc, 0x44, 0x9f, 0x83, + 0x54, 0xc7, 0xd4, 0x6d, 0xd3, 0x28, 0x66, 0x98, 0x46, 0xd9, 0x1b, 0x7a, 0x0b, 0x44, 0xdd, 0x90, + 0xf7, 0x5a, 0x7a, 0x73, 0xdf, 0x91, 0x0f, 0x2c, 0xdd, 0xc1, 0x76, 0x71, 0x96, 0x16, 0x3c, 0xcc, + 0x2c, 0xea, 0x7c, 0x31, 0x56, 0x7b, 0x9b, 0xe4, 0xe4, 0x55, 0x28, 0xe8, 0xc6, 0x5d, 0xca, 0x4f, + 0x89, 0xb6, 0xe7, 0x12, 0x4c, 0x8b, 0xe9, 0xd2, 0xbf, 0x0a, 0x70, 0xae, 0xdf, 0x4c, 0xa2, 0xec, + 0xa6, 0xd7, 0x41, 0x34, 0x0d, 0x2c, 0x77, 0xf6, 0x15, 0x1b, 0xf3, 0x66, 0xe5, 0xf3, 0x57, 0xc1, + 0x34, 0xf0, 0x36, 0x21, 0xb3, 0x46, 0x42, 0xdb, 0x30, 0x6b, 0x3b, 0x4a, 0x53, 0x37, 0x9a, 0xb2, + 0xb7, 0x8c, 0x4f, 0xd7, 0x62, 0x26, 0x74, 0xfe, 0x45, 0xce, 0xed, 0xd1, 0x7b, 0x9c, 0x9e, 0x7f, + 0x10, 0x60, 0x76, 0x45, 0x6b, 0xeb, 0x46, 0xbd, 0xd3, 0xd2, 0x23, 0x5d, 0x29, 0xb8, 0x0c, 0x19, + 0x9b, 0xc8, 0xf4, 0xe7, 0x20, 0x1f, 0xe5, 0xa5, 0x69, 0x0a, 0x99, 0x8c, 0x1e, 0xc0, 0x0c, 0x3e, + 0xec, 0xe8, 0x96, 0x42, 0x54, 0xcc, 0x80, 0x4d, 0x72, 0xf2, 0xba, 0x15, 0x7c, 0x5e, 0x1f, 0xdc, + 0xf0, 0x9a, 0x3d, 0x02, 0x14, 0xac, 0x58, 0x94, 0x63, 0x88, 0x0c, 0x73, 0x54, 0xf4, 0x8e, 0x61, + 0x47, 0xac, 0x35, 0x3e, 0x0a, 0x7e, 0x09, 0xce, 0xf4, 0x7e, 0x20, 0xca, 0xd2, 0xbf, 0xcb, 0x5b, + 0x7c, 0x03, 0x5b, 0x1f, 0x13, 0xb8, 0x0e, 0x8a, 0x8f, 0xb2, 0xe4, 0x5f, 0x13, 0xe0, 0x02, 0x95, + 0x4d, 0xbb, 0xe5, 0x1e, 0xb6, 0xe8, 0x0e, 0x51, 0x94, 0x46, 0x7b, 0x09, 0x52, 0x0c, 0x2b, 0x53, + 0x8b, 0x9d, 0x5a, 0xcd, 0x12, 0xf7, 0xaa, 0xee, 0x98, 0x16, 0x71, 0xaf, 0x78, 0x12, 0xaf, 0xa7, + 0x02, 0xf3, 0x61, 0x65, 0x89, 0xb2, 0xbe, 0x7f, 0x1e, 0xe7, 0xdf, 0x28, 0xef, 0x33, 0x98, 0xde, + 0x69, 0xe9, 0xaa, 0x12, 0xa9, 0xb7, 0x52, 0x81, 0xac, 0x4a, 0x85, 0xcb, 0xce, 0x51, 0x87, 0x2d, + 0x2a, 0x14, 0x6e, 0x5f, 0x0e, 0x15, 0x44, 0x3f, 0xce, 0x4a, 0xd2, 0x38, 0xea, 0x60, 0xe2, 0x68, + 0xbb, 0xcf, 0x68, 0x0d, 0xa6, 0x99, 0x72, 0x5c, 0x8c, 0x32, 0x42, 0x04, 0xed, 0xad, 0x34, 0x33, + 0xef, 0xc5, 0x2e, 0x2b, 0x2a, 0x43, 0x1a, 0x1f, 0x76, 0x64, 0xba, 0xab, 0x98, 0x3c, 0xe1, 0xae, + 0xe2, 0x34, 0x3e, 0xec, 0x10, 0x22, 0x6f, 0x9d, 0xf7, 0x05, 0x78, 0x2e, 0x54, 0x75, 0x51, 0x0e, + 0xe2, 0xee, 0x0e, 0x68, 0xfc, 0x34, 0x3b, 0xa0, 0xa5, 0x3f, 0x72, 0xad, 0x59, 0xc2, 0x2d, 0x53, + 0x55, 0x3e, 0x86, 0x45, 0xc0, 0x40, 0xab, 0xc4, 0x4f, 0xdd, 0x2a, 0x7d, 0xe6, 0xde, 0x57, 0xd8, + 0x28, 0xcd, 0xfd, 0xb7, 0x04, 0x98, 0xab, 0x62, 0xc5, 0x72, 0x76, 0xb1, 0xe2, 0x34, 0x0e, 0x23, + 0x75, 0xcc, 0x5e, 0x85, 0x84, 0x61, 0x1e, 0x9c, 0x64, 0xd1, 0x8c, 0xe4, 0xf7, 0x87, 0xe3, 0xde, + 0x72, 0x45, 0x59, 0xeb, 0xbf, 0x8d, 0x43, 0xe6, 0x5e, 0x39, 0xca, 0xba, 0x7e, 0x96, 0x2f, 0xad, + 0xb2, 0x9e, 0x18, 0x66, 0x96, 0xde, 0xf7, 0x96, 0xef, 0x95, 0xd7, 0xf1, 0x91, 0x6b, 0x96, 0x84, + 0x0b, 0xad, 0x40, 0xc6, 0xd9, 0x27, 0xfe, 0x97, 0xd9, 0xd2, 0x4e, 0x32, 0x17, 0xfb, 0x5c, 0xf3, + 0x8f, 0x61, 0x8a, 0xca, 0x75, 0x37, 0xe7, 0x85, 0x90, 0xcd, 0x79, 0xf2, 0x19, 0xcf, 0x9d, 0x89, + 0x9f, 0xe4, 0x33, 0x2e, 0x81, 0x35, 0x8e, 0x37, 0xe7, 0x4f, 0x89, 0xa9, 0xd2, 0x5b, 0x00, 0xa4, + 0x6a, 0x51, 0x36, 0xcf, 0x5f, 0x24, 0xa0, 0xb0, 0xdd, 0xb5, 0xf7, 0x23, 0xb6, 0xc7, 0x32, 0x40, + 0xa7, 0x6b, 0xef, 0x63, 0x4b, 0x76, 0x0e, 0x0d, 0x5e, 0xff, 0x31, 0xdb, 0xfe, 0xae, 0x02, 0x18, + 0x5f, 0xe3, 0xd0, 0x40, 0x5b, 0x5c, 0x08, 0x96, 0xfd, 0xd8, 0x81, 0x1b, 0x13, 0x40, 0xbd, 0xc6, + 0xa1, 0xb1, 0x81, 0x3d, 0x8c, 0xc7, 0x04, 0x62, 0x22, 0xf0, 0xb3, 0x30, 0x4d, 0x5e, 0x64, 0xc7, + 0x3c, 0x49, 0xcb, 0xa7, 0x08, 0x4f, 0xc3, 0x44, 0x6f, 0x40, 0x86, 0x71, 0x93, 0x99, 0x24, 0x45, + 0x67, 0x92, 0xb0, 0x2a, 0x71, 0x6d, 0xd2, 0x39, 0x24, 0x4d, 0x59, 0xc9, 0x0c, 0x72, 0x06, 0xa6, + 0xf6, 0x4c, 0x4b, 0xc5, 0x34, 0x58, 0x20, 0x2d, 0xb1, 0x17, 0x74, 0x03, 0x66, 0x75, 0x43, 0x6d, + 0x75, 0x6d, 0xfd, 0x09, 0x96, 0xdd, 0xa2, 0x31, 0x20, 0x30, 0xe3, 0x25, 0x50, 0x81, 0x66, 0xd0, + 0x10, 0xee, 0x27, 0xd3, 0x69, 0x31, 0x53, 0xfa, 0x96, 0x00, 0x33, 0x5e, 0xdb, 0x45, 0x39, 0xf0, + 0x97, 0x7b, 0x14, 0x7f, 0xf2, 0xd6, 0x23, 0xca, 0x2e, 0xfd, 0xbd, 0x00, 0xb3, 0x12, 0x56, 0xcd, + 0x27, 0xb4, 0x31, 0xa3, 0x34, 0xae, 0x55, 0x16, 0x4c, 0x12, 0x3f, 0xa5, 0x41, 0xd0, 0xf0, 0x92, + 0x5b, 0x70, 0x46, 0x6f, 0x93, 0x99, 0x41, 0x77, 0x5a, 0x47, 0x1c, 0xa1, 0x38, 0xd8, 0xdd, 0xef, + 0x9c, 0xf3, 0xd3, 0xca, 0x6e, 0x12, 0x1f, 0x2c, 0xd9, 0x0e, 0x88, 0x5f, 0xad, 0x28, 0xf5, 0x5e, + 0x83, 0xbc, 0xc5, 0x44, 0x63, 0xed, 0xc4, 0xaa, 0xcf, 0x79, 0xac, 0x44, 0xfb, 0xdf, 0x89, 0xc3, + 0xcc, 0x5b, 0x5d, 0x6c, 0x1d, 0x7d, 0x02, 0x75, 0x7f, 0x15, 0x66, 0x0e, 0x14, 0xdd, 0x91, 0xf7, + 0x4c, 0x4b, 0xee, 0x76, 0x34, 0xc5, 0x71, 0xc3, 0x1e, 0xf2, 0x84, 0x7c, 0xd7, 0xb4, 0x76, 0x28, + 0x11, 0x61, 0x40, 0x8f, 0x0d, 0xf3, 0xc0, 0x90, 0x09, 0x99, 0x02, 0xc4, 0x43, 0x83, 0x2f, 0xee, + 0xae, 0x7e, 0xe6, 0x1f, 0x8f, 0x17, 0xef, 0x4c, 0x14, 0xc8, 0x44, 0x63, 0xc1, 0xba, 0x5d, 0x5d, + 0x5b, 0xde, 0xd9, 0xa9, 0xad, 0x49, 0x22, 0x15, 0xf9, 0x36, 0x93, 0xd8, 0x38, 0x34, 0x5c, 0x07, + 0xe0, 0x23, 0x01, 0x44, 0x5f, 0x61, 0x51, 0xb6, 0x6a, 0x05, 0xb2, 0xef, 0x75, 0xb1, 0xa5, 0x9f, + 0xa2, 0x4d, 0x81, 0x33, 0x92, 0xc1, 0xeb, 0x1d, 0xc8, 0xf5, 0xe8, 0x21, 0xf1, 0x8b, 0xe9, 0x21, + 0x7b, 0xe0, 0xab, 0xa0, 0xf4, 0x03, 0x01, 0x10, 0xad, 0x7c, 0x8d, 0xad, 0xab, 0x7f, 0xc2, 0x0c, + 0xe6, 0x3a, 0x88, 0x34, 0xb4, 0x50, 0xd6, 0xf7, 0xe4, 0xb6, 0x6e, 0xdb, 0xba, 0xd1, 0xe4, 0x16, + 0x53, 0xa0, 0xf4, 0xda, 0xde, 0x06, 0xa3, 0xf2, 0xb6, 0xfc, 0x15, 0x98, 0xeb, 0xa9, 0x4d, 0x94, + 0xad, 0x79, 0x11, 0x72, 0x7b, 0x66, 0xd7, 0xd0, 0x64, 0xb6, 0x40, 0xc4, 0x17, 0xc2, 0xb2, 0x94, + 0xc6, 0xbe, 0x57, 0xfa, 0x6a, 0x1c, 0xce, 0x48, 0xd8, 0x36, 0x5b, 0x4f, 0x70, 0xf4, 0xfa, 0xdc, + 0x02, 0xbe, 0xf9, 0x21, 0xff, 0x22, 0x6a, 0xcd, 0x30, 0x19, 0x6c, 0x52, 0xec, 0x5d, 0x2f, 0xbf, + 0x3c, 0xda, 0x32, 0x07, 0x57, 0xc8, 0xf9, 0xfa, 0x55, 0x32, 0xb8, 0x7e, 0xc5, 0x1b, 0xe2, 0x97, + 0xe0, 0x6c, 0x9f, 0x22, 0xa2, 0xf4, 0x5d, 0x7e, 0x14, 0x87, 0x0b, 0xbd, 0xe2, 0xa3, 0x46, 0x18, + 0xff, 0x3b, 0x94, 0x8d, 0xaa, 0x90, 0x6f, 0xeb, 0xc6, 0xe9, 0xd6, 0xcf, 0x72, 0x04, 0xe3, 0xf7, + 0xfa, 0x9c, 0x04, 0x0c, 0x85, 0xe9, 0x35, 0xca, 0xb6, 0xfb, 0x86, 0x00, 0xb9, 0xa8, 0x57, 0x68, + 0x4e, 0x17, 0xeb, 0xc4, 0xeb, 0xdc, 0x80, 0xfc, 0xc7, 0xb0, 0xa4, 0xf3, 0x07, 0x02, 0xa0, 0x86, + 0xd5, 0x35, 0x08, 0xa4, 0x7c, 0x60, 0x36, 0xa3, 0xac, 0xec, 0x19, 0x98, 0xd2, 0x0d, 0x0d, 0x1f, + 0xd2, 0xca, 0x26, 0x25, 0xf6, 0xd2, 0xb3, 0x9b, 0x96, 0x98, 0x68, 0x37, 0xcd, 0x0f, 0x99, 0xe8, + 0x29, 0x68, 0x94, 0x5a, 0xf8, 0x4e, 0x1c, 0xe6, 0x78, 0x75, 0x22, 0x5f, 0xd2, 0x3a, 0x55, 0xa0, + 0x35, 0xfa, 0x1c, 0x40, 0xc7, 0xc2, 0x4f, 0x64, 0xc6, 0x9a, 0x98, 0x88, 0x35, 0x43, 0x38, 0x28, + 0x01, 0x7d, 0x11, 0x66, 0x48, 0x87, 0xeb, 0x58, 0x66, 0xc7, 0xb4, 0xc9, 0xbc, 0x6e, 0x4f, 0x06, + 0x28, 0x66, 0x9f, 0x1d, 0x2f, 0xe6, 0x37, 0x74, 0x63, 0x9b, 0x33, 0x36, 0xea, 0x12, 0xe9, 0xb9, + 0xde, 0xab, 0xeb, 0x8c, 0xfc, 0x50, 0x80, 0x33, 0x1f, 0xdb, 0x22, 0xe0, 0xff, 0x84, 0xc6, 0xbc, + 0xf9, 0x40, 0xa4, 0xaf, 0x35, 0x63, 0xcf, 0x8c, 0x7e, 0x69, 0xf6, 0x1b, 0x02, 0xcc, 0x06, 0xc4, + 0x47, 0x39, 0xeb, 0x9f, 0x2e, 0x9c, 0xff, 0x4b, 0xc4, 0x0f, 0x08, 0x9a, 0x7d, 0x94, 0x9d, 0xea, + 0xdf, 0x05, 0x38, 0x57, 0x66, 0xfb, 0xac, 0x6e, 0xe8, 0x40, 0x94, 0x56, 0x52, 0x84, 0xe9, 0x27, + 0xd8, 0xb2, 0x75, 0x93, 0xcd, 0x7b, 0x79, 0xc9, 0x7d, 0x45, 0xf3, 0x90, 0xb6, 0x0d, 0xa5, 0x63, + 0xef, 0x9b, 0xee, 0x9e, 0x8e, 0xf7, 0xee, 0x85, 0x39, 0x4c, 0x9d, 0x3e, 0xcc, 0x21, 0x15, 0x1e, + 0xe6, 0xc0, 0xb7, 0x3d, 0xbe, 0x2f, 0xc0, 0xf9, 0x81, 0x5a, 0x47, 0xd9, 0xd2, 0x5f, 0x81, 0xac, + 0xca, 0x05, 0x93, 0x31, 0x94, 0xed, 0xec, 0xd4, 0x48, 0xb6, 0x53, 0x7a, 0xda, 0xcf, 0x8e, 0x17, + 0xc1, 0x2d, 0x6a, 0x6d, 0x8d, 0x57, 0x8c, 0x3c, 0x6b, 0xa5, 0x9f, 0x02, 0xe4, 0x2b, 0x87, 0x1d, + 0xd3, 0x72, 0xea, 0xcc, 0x91, 0x40, 0x6b, 0x90, 0xee, 0x58, 0xe6, 0x13, 0xdd, 0xad, 0x44, 0x21, + 0x74, 0xfb, 0xb3, 0x87, 0x67, 0x9b, 0xe7, 0x97, 0x3c, 0x4e, 0x24, 0x41, 0xe6, 0x81, 0xa9, 0x2a, + 0xad, 0xbb, 0x7a, 0xcb, 0xb5, 0xd8, 0xe5, 0x71, 0x62, 0x96, 0x3d, 0x8e, 0x6d, 0xc5, 0xd9, 0x77, + 0x3b, 0xb0, 0x47, 0x44, 0xf7, 0x20, 0x5d, 0x75, 0x9c, 0x0e, 0x49, 0xe4, 0xbd, 0xff, 0xca, 0x58, + 0x91, 0x84, 0x81, 0x4b, 0xf2, 0x98, 0x91, 0x04, 0xb3, 0xf7, 0x4c, 0xb3, 0xd9, 0xc2, 0xe5, 0x96, + 0xd9, 0xd5, 0xca, 0xa6, 0xb1, 0xa7, 0x37, 0xf9, 0xe8, 0x79, 0x79, 0xac, 0xc4, 0x7b, 0xe5, 0xba, + 0x34, 0xc8, 0x8e, 0x3e, 0x0f, 0xe9, 0xfa, 0x1d, 0x2e, 0x8a, 0xf9, 0x3e, 0x97, 0xc6, 0x8a, 0xaa, + 0xdf, 0x91, 0x3c, 0x26, 0x54, 0x85, 0xec, 0xca, 0xd3, 0xae, 0x85, 0xb9, 0x8c, 0x14, 0x95, 0x71, + 0x75, 0xac, 0x0c, 0xca, 0x23, 0x05, 0x59, 0xd1, 0x5b, 0x50, 0x78, 0xdb, 0xb4, 0x1e, 0xb7, 0x4c, + 0xc5, 0xad, 0xdb, 0x34, 0x15, 0xf6, 0xe2, 0x58, 0x61, 0x2e, 0x9b, 0xd4, 0x27, 0x60, 0xfe, 0x8b, + 0x90, 0xef, 0x69, 0x1c, 0x84, 0x20, 0xd9, 0x21, 0xed, 0x20, 0xd0, 0xa0, 0x14, 0xfa, 0x8c, 0x5e, + 0x81, 0x69, 0xc3, 0xd4, 0xb0, 0x6b, 0xb3, 0xf9, 0xd5, 0x33, 0xcf, 0x8e, 0x17, 0x53, 0x9b, 0xa6, + 0xc6, 0xa6, 0x7d, 0xfe, 0x24, 0xa5, 0x48, 0x26, 0x77, 0xd2, 0x9f, 0xbf, 0x0a, 0x49, 0xd2, 0x2e, + 0xa4, 0xb3, 0xef, 0x2a, 0x36, 0xde, 0xb1, 0x74, 0x2e, 0xd3, 0x7d, 0xe5, 0xf9, 0xfe, 0x46, 0x80, + 0x78, 0xfd, 0x0e, 0xf1, 0x3f, 0x77, 0xbb, 0xea, 0x63, 0xec, 0xf0, 0x5c, 0xfc, 0x8d, 0xfa, 0xa5, + 0x16, 0xde, 0xd3, 0x99, 0x2f, 0x92, 0x91, 0xf8, 0x1b, 0x7a, 0x01, 0x40, 0x51, 0x55, 0x6c, 0xdb, + 0xb2, 0x7b, 0x86, 0x29, 0x23, 0x65, 0x18, 0x65, 0x1d, 0x1f, 0x11, 0x36, 0x1b, 0xab, 0x16, 0x76, + 0xdc, 0xe8, 0x1a, 0xf6, 0x46, 0xd8, 0x1c, 0xdc, 0xee, 0xc8, 0x8e, 0xf9, 0x18, 0x1b, 0xb4, 0x3d, + 0x33, 0x52, 0x86, 0x50, 0x1a, 0x84, 0x40, 0xc6, 0x1f, 0x6c, 0x68, 0xfe, 0x60, 0x91, 0x91, 0xbc, + 0x77, 0x22, 0xd2, 0xc2, 0x4d, 0x9d, 0x1f, 0xca, 0xc9, 0x48, 0xfc, 0x8d, 0x57, 0xe3, 0x9b, 0x02, + 0x24, 0xee, 0x95, 0xeb, 0x27, 0xae, 0x07, 0x82, 0xa4, 0xd2, 0xe5, 0x76, 0x9f, 0x91, 0xe8, 0x33, + 0x0d, 0x3b, 0xd3, 0x5b, 0x2d, 0x02, 0xc7, 0x3b, 0x96, 0xf9, 0x15, 0xac, 0xba, 0xb5, 0x28, 0x70, + 0xf2, 0x36, 0xa3, 0xa2, 0x25, 0xc8, 0xaa, 0x16, 0xd6, 0xb0, 0xe1, 0xe8, 0x4a, 0xcb, 0xe6, 0xd5, + 0x09, 0x92, 0x78, 0xe1, 0xbe, 0x2a, 0xc0, 0x14, 0x35, 0x24, 0xf4, 0x3c, 0x64, 0x54, 0xd3, 0x70, + 0x14, 0xdd, 0xe0, 0xa3, 0x40, 0x46, 0xf2, 0x09, 0x43, 0x0b, 0x79, 0x11, 0x72, 0x8a, 0xaa, 0x9a, + 0x5d, 0xc3, 0x91, 0x0d, 0xa5, 0x8d, 0x79, 0x61, 0xb3, 0x9c, 0xb6, 0xa9, 0xb4, 0x31, 0x5a, 0x04, + 0xf7, 0xd5, 0x3b, 0x35, 0x96, 0x91, 0x80, 0x93, 0xd6, 0xf1, 0x11, 0x2f, 0xc9, 0xf7, 0x05, 0x48, + 0xbb, 0x26, 0x48, 0x0a, 0xd3, 0xc4, 0x06, 0xb6, 0x14, 0xc7, 0xf4, 0x0a, 0xe3, 0x11, 0xfa, 0x67, + 0x89, 0x8c, 0x3f, 0x4b, 0x9c, 0x81, 0x29, 0x47, 0xd9, 0x6d, 0xb9, 0xe5, 0x60, 0x2f, 0x74, 0x19, + 0xb4, 0xa5, 0x34, 0xd9, 0x2a, 0x4e, 0x46, 0x62, 0x2f, 0xa4, 0x4a, 0x3c, 0xce, 0x91, 0x69, 0x87, + 0xbf, 0x91, 0xf2, 0xb2, 0xd0, 0xbe, 0x5d, 0xdc, 0xd4, 0x0d, 0xda, 0xd8, 0x09, 0x09, 0x28, 0x89, + 0x46, 0xd1, 0xa0, 0xe7, 0x20, 0xc3, 0x32, 0x60, 0x43, 0xa3, 0x2d, 0x9e, 0x90, 0xd2, 0x94, 0x50, + 0x71, 0x8f, 0xc9, 0x70, 0xd7, 0xe0, 0x8f, 0x05, 0x98, 0x65, 0xb1, 0x11, 0x2c, 0x26, 0x30, 0xba, + 0x79, 0xf2, 0x75, 0xc8, 0x68, 0x8a, 0xa3, 0xb0, 0x53, 0x6a, 0xf1, 0x91, 0xa7, 0xd4, 0xdc, 0xa1, + 0x90, 0xe4, 0xa7, 0x27, 0xd5, 0x10, 0x24, 0xc9, 0x33, 0x3b, 0xdd, 0x27, 0xd1, 0x67, 0x7f, 0x97, + 0x39, 0x58, 0xdc, 0x28, 0xfd, 0x86, 0x1f, 0x27, 0xdc, 0x49, 0x27, 0x4a, 0x35, 0x7c, 0x01, 0xa6, + 0x39, 0x18, 0xe6, 0x4a, 0x58, 0x1a, 0x37, 0xde, 0xb9, 0xfb, 0x70, 0x9c, 0x0d, 0xad, 0x02, 0xb0, + 0xa0, 0x3e, 0x1a, 0x25, 0x91, 0x38, 0xc1, 0x96, 0x09, 0x65, 0x23, 0x54, 0xb4, 0x09, 0xd9, 0xf6, + 0x13, 0x55, 0x95, 0xf7, 0xf4, 0x96, 0xc3, 0x03, 0x88, 0xc2, 0xa3, 0x66, 0x37, 0x1e, 0x96, 0xcb, + 0x77, 0x69, 0x26, 0x16, 0xc7, 0xe3, 0xbf, 0x4b, 0x40, 0x24, 0xb0, 0x67, 0xf4, 0x32, 0xf0, 0x33, + 0x05, 0xb2, 0xed, 0x9e, 0x10, 0x5a, 0xcd, 0x3f, 0x3b, 0x5e, 0xcc, 0x48, 0x94, 0x5a, 0xaf, 0x37, + 0xa4, 0x0c, 0xcb, 0x50, 0xb7, 0x1d, 0x74, 0x09, 0xf2, 0x66, 0x5b, 0x77, 0x64, 0x77, 0x86, 0xe7, + 0xae, 0x4c, 0x8e, 0x10, 0x5d, 0x0f, 0x00, 0x35, 0xe0, 0x1a, 0x36, 0x48, 0x5f, 0xa0, 0xf5, 0x64, + 0xd1, 0xe2, 0xb2, 0xee, 0xb0, 0xfe, 0x24, 0x9b, 0x1d, 0x47, 0x6f, 0xeb, 0x4f, 0xe9, 0x76, 0x25, + 0xdf, 0x2a, 0xb8, 0xc4, 0xb2, 0x93, 0xfa, 0xd1, 0xf8, 0xf1, 0x1a, 0xcf, 0xbb, 0x15, 0xc8, 0xca, + 0xad, 0xe6, 0xeb, 0x02, 0xe4, 0x57, 0xbb, 0xad, 0xc7, 0x5b, 0x9d, 0x7a, 0xb7, 0xdd, 0x56, 0xac, + 0x23, 0xd2, 0x41, 0x98, 0x75, 0xea, 0x4f, 0x31, 0x8b, 0xae, 0xe4, 0xe6, 0xa7, 0x3f, 0xc5, 0xc4, + 0xfc, 0x78, 0xd0, 0x2e, 0xa1, 0xb3, 0x88, 0xdc, 0x4b, 0x90, 0xa7, 0x40, 0x52, 0xc6, 0x86, 0x63, + 0xe9, 0x98, 0xad, 0x53, 0x24, 0xa4, 0x1c, 0x25, 0x56, 0x18, 0x0d, 0x5d, 0x81, 0x82, 0x7d, 0x64, + 0x3b, 0xb8, 0x2d, 0xb3, 0xb3, 0xb5, 0x0c, 0xfd, 0x24, 0xa4, 0x3c, 0xa3, 0x4a, 0x8c, 0x58, 0xfa, + 0x93, 0x04, 0x14, 0x5c, 0x4b, 0x8b, 0xd2, 0x45, 0x5b, 0x85, 0xa9, 0x3d, 0xbd, 0x85, 0xdd, 0x5d, + 0xdf, 0xe1, 0xd3, 0xb4, 0x17, 0xd6, 0x49, 0x66, 0x4e, 0xd7, 0x35, 0xa7, 0xac, 0x51, 0x58, 0xdb, + 0xfc, 0x87, 0x02, 0x24, 0xa9, 0x6f, 0x74, 0x0b, 0x92, 0xb4, 0xfb, 0x0b, 0x93, 0x74, 0x7f, 0x9a, + 0xd5, 0x9b, 0xc2, 0xe3, 0x81, 0x29, 0x9c, 0xcc, 0x87, 0xfb, 0xca, 0xab, 0xb7, 0x6e, 0x53, 0x4b, + 0xcb, 0x49, 0xfc, 0x0d, 0xad, 0xd2, 0xb8, 0x01, 0xd3, 0x72, 0xb0, 0xc6, 0x3d, 0x93, 0xb0, 0xce, + 0xd5, 0xd3, 0xf0, 0xee, 0x50, 0xe3, 0xf2, 0xa1, 0x0b, 0x90, 0x20, 0x26, 0x3c, 0xcd, 0xb6, 0x2a, + 0x9f, 0x1d, 0x2f, 0x26, 0x88, 0xf1, 0x12, 0x1a, 0x73, 0xac, 0xef, 0x27, 0xd3, 0x49, 0x71, 0xaa, + 0xf4, 0xdd, 0x24, 0xe4, 0x6b, 0xed, 0xa8, 0x07, 0x87, 0x95, 0xde, 0x06, 0x0b, 0x73, 0x1c, 0x7b, + 0x3e, 0x1a, 0xd2, 0x5e, 0x3d, 0xc3, 0x6c, 0xe2, 0x64, 0xc3, 0x6c, 0x8d, 0x38, 0x05, 0xfc, 0x38, + 0x30, 0xf9, 0xfe, 0x4b, 0x63, 0xbf, 0xdf, 0x20, 0x3d, 0x4e, 0x22, 0x3c, 0x7e, 0xdc, 0x32, 0xdd, + 0x3d, 0x7e, 0x93, 0xfa, 0x1e, 0xcc, 0x68, 0x52, 0x93, 0x1b, 0xcd, 0x34, 0x36, 0x34, 0x6a, 0x32, + 0x87, 0xdc, 0x62, 0x5e, 0x83, 0x84, 0xa6, 0x8f, 0x52, 0x69, 0xd8, 0x50, 0x49, 0x58, 0xc6, 0x18, + 0x4e, 0x32, 0x68, 0x38, 0x41, 0xe0, 0x34, 0xbf, 0x05, 0xe0, 0xd7, 0x0a, 0x2d, 0x41, 0xca, 0x6c, + 0x69, 0x6e, 0xc8, 0x75, 0x7e, 0x35, 0xf3, 0xec, 0x78, 0x71, 0x6a, 0xab, 0xa5, 0xd5, 0xd6, 0xa4, + 0x29, 0xb3, 0xa5, 0xd5, 0x34, 0x7a, 0x8a, 0x1a, 0x1f, 0xc8, 0x5e, 0x00, 0x48, 0x4e, 0x9a, 0x36, + 0xf0, 0x81, 0x1f, 0x82, 0xe2, 0x09, 0x27, 0x66, 0xf3, 0x7b, 0x02, 0x14, 0x5c, 0x0d, 0x46, 0xdb, + 0xd3, 0xd3, 0x7a, 0x9b, 0x5b, 0x7e, 0xe2, 0x64, 0x96, 0xef, 0xf2, 0xf1, 0xb3, 0x5e, 0x5f, 0x13, + 0x78, 0x50, 0x5b, 0x5d, 0x55, 0x1c, 0x32, 0xcc, 0x47, 0x68, 0xde, 0x2f, 0x82, 0x68, 0x29, 0x86, + 0x66, 0xb6, 0xf5, 0xa7, 0x98, 0xad, 0x8f, 0xd8, 0x7c, 0x5b, 0x60, 0xc6, 0xa3, 0xd3, 0x05, 0x00, + 0x77, 0x79, 0xe7, 0xdf, 0x04, 0x1e, 0x00, 0xe7, 0x15, 0x26, 0x4a, 0xa5, 0xad, 0x43, 0x8a, 0x2e, + 0xed, 0xb9, 0xdd, 0xed, 0x95, 0x10, 0x21, 0x61, 0x5f, 0x67, 0xd1, 0x3c, 0x9e, 0xc1, 0x53, 0x11, + 0xf3, 0x5f, 0x80, 0x29, 0x4a, 0x3e, 0xc5, 0x18, 0xc7, 0x35, 0xff, 0x9f, 0x34, 0x04, 0x53, 0xab, + 0xd7, 0xb9, 0xf9, 0x45, 0xa7, 0x77, 0xd7, 0x7d, 0x8a, 0xfb, 0xee, 0x13, 0x7a, 0x05, 0x90, 0xa6, + 0xdb, 0xec, 0x8c, 0xaf, 0xbd, 0xaf, 0x68, 0xe6, 0x81, 0xbf, 0x59, 0x34, 0xeb, 0xa6, 0xd4, 0xdd, + 0x04, 0xf4, 0x0e, 0xd0, 0xe9, 0x5e, 0xb6, 0x1d, 0xc5, 0x5b, 0xc3, 0x7b, 0xf9, 0x24, 0xd1, 0xe4, + 0xcc, 0x1d, 0xf0, 0x5e, 0xa5, 0x0c, 0x11, 0x47, 0x1f, 0x83, 0xf1, 0x82, 0x7e, 0xed, 0xa3, 0xf4, + 0xe4, 0x3a, 0x50, 0xe0, 0xb1, 0xc4, 0x11, 0xaf, 0x2b, 0xd3, 0x78, 0x63, 0x6e, 0xc2, 0xec, 0xc5, + 0x3f, 0xce, 0xeb, 0x7d, 0x31, 0xca, 0x9a, 0x74, 0x61, 0xce, 0x95, 0x1b, 0xf5, 0x16, 0xce, 0xa8, + 0xea, 0xd0, 0xf5, 0xb9, 0xe0, 0x67, 0xa3, 0xac, 0xd3, 0xbf, 0x08, 0x50, 0xa8, 0x77, 0x77, 0xd9, + 0x9d, 0x0e, 0x51, 0x46, 0x34, 0x66, 0x5a, 0x78, 0xcf, 0x91, 0x4f, 0x15, 0x99, 0x97, 0x26, 0xac, + 0x84, 0x8a, 0x56, 0x00, 0x2c, 0x1a, 0x5b, 0x4e, 0xe5, 0x24, 0x26, 0x95, 0x23, 0x65, 0x28, 0x57, + 0x20, 0x12, 0xf1, 0xbb, 0x71, 0x98, 0xf1, 0xaa, 0x19, 0xe5, 0x30, 0xf6, 0xcb, 0x3d, 0x5d, 0x33, + 0x71, 0x8a, 0xae, 0x39, 0x4b, 0x64, 0x0e, 0xeb, 0x9e, 0x68, 0x19, 0xe6, 0xe8, 0x58, 0x2d, 0x2b, + 0x9d, 0x4e, 0x4b, 0xc7, 0x9a, 0xcc, 0x76, 0x53, 0x92, 0x74, 0x37, 0x65, 0x96, 0x26, 0xad, 0xb0, + 0x94, 0x1a, 0xdd, 0x59, 0xb9, 0x0b, 0xb9, 0x3d, 0x0b, 0xe3, 0xa7, 0x58, 0xa6, 0x1e, 0xe0, 0x49, + 0xf6, 0xd8, 0xb2, 0x8c, 0xb1, 0x4e, 0xf8, 0xf8, 0xa8, 0xf8, 0x2e, 0xcc, 0x52, 0xd5, 0x46, 0x7d, + 0x3e, 0x87, 0xb7, 0xca, 0x4f, 0x05, 0x40, 0x41, 0xf9, 0x1f, 0x5f, 0xc3, 0xc4, 0x23, 0x6f, 0x98, + 0x97, 0x01, 0xb1, 0xb0, 0x07, 0x5b, 0xee, 0x60, 0x4b, 0xb6, 0xb1, 0x6a, 0xf2, 0x8b, 0x08, 0x04, + 0x49, 0xe4, 0x29, 0xdb, 0xd8, 0xaa, 0x53, 0x7a, 0xe9, 0x3f, 0x2e, 0x40, 0x8e, 0xeb, 0x64, 0xc7, + 0xd0, 0x4d, 0x03, 0xdd, 0x82, 0x44, 0x93, 0xaf, 0xec, 0x64, 0x43, 0xb1, 0x9f, 0x7f, 0x19, 0x4a, + 0x35, 0x26, 0x91, 0xbc, 0x84, 0xa5, 0xd3, 0x75, 0x42, 0xc2, 0xf4, 0xfc, 0x98, 0xae, 0x20, 0x4b, + 0xa7, 0xeb, 0xa0, 0x3a, 0xcc, 0xa8, 0xfe, 0x65, 0x10, 0x32, 0x61, 0x4f, 0x0c, 0x3d, 0xae, 0x12, + 0x7a, 0xa5, 0x46, 0x35, 0x26, 0x15, 0xd4, 0x9e, 0x04, 0x54, 0x0e, 0xde, 0x3e, 0x90, 0x1c, 0xba, + 0x8e, 0xd9, 0x7f, 0xf3, 0x41, 0x35, 0x16, 0xb8, 0xa4, 0x00, 0xbd, 0x0e, 0x29, 0x8d, 0x9e, 0x6a, + 0xe7, 0x16, 0x1a, 0x66, 0x44, 0x3d, 0x17, 0x09, 0x54, 0x63, 0x12, 0xe7, 0x40, 0xf7, 0x21, 0xc7, + 0x9e, 0xd8, 0x59, 0x66, 0xee, 0xe2, 0x5e, 0x19, 0x2e, 0x21, 0x30, 0x5a, 0x57, 0x63, 0x52, 0x56, + 0xf3, 0xa9, 0xe8, 0xd3, 0x90, 0xb4, 0x55, 0xc5, 0xe0, 0xcb, 0x9f, 0x0b, 0x43, 0x8e, 0xae, 0xfa, + 0xcc, 0x34, 0x37, 0x7a, 0x04, 0xb3, 0x74, 0xb1, 0x47, 0x76, 0xfc, 0x5d, 0x70, 0x7a, 0x74, 0xa6, + 0x77, 0xe3, 0xdd, 0x73, 0xfd, 0xc2, 0x4f, 0x6c, 0x55, 0x63, 0x92, 0xb8, 0xdb, 0x97, 0x44, 0x9a, + 0x8c, 0xfa, 0xee, 0x01, 0xc1, 0x99, 0xa1, 0x4d, 0x16, 0x7a, 0x86, 0x8a, 0x34, 0x19, 0xee, 0x49, + 0x40, 0xf7, 0x20, 0xab, 0x10, 0x5f, 0x4a, 0xa6, 0x27, 0x19, 0x8a, 0x30, 0x74, 0x1d, 0x7b, 0xe0, + 0x14, 0x4a, 0x95, 0x1e, 0x3f, 0x73, 0x89, 0xbe, 0xa0, 0x36, 0xb6, 0x9a, 0xb8, 0x98, 0x1d, 0x2d, + 0x28, 0xb8, 0x75, 0xee, 0x09, 0xa2, 0x44, 0xb4, 0x01, 0xf9, 0x7d, 0x37, 0x9a, 0x97, 0x86, 0x2d, + 0xe4, 0x86, 0x2e, 0x66, 0x87, 0x44, 0x23, 0x57, 0x63, 0x52, 0x6e, 0x3f, 0x40, 0x46, 0xcb, 0x10, + 0x6f, 0xaa, 0xc5, 0x3c, 0x95, 0xf1, 0xfc, 0xa8, 0x58, 0xdb, 0x6a, 0x4c, 0x8a, 0x37, 0x55, 0x82, + 0x90, 0x58, 0x20, 0xe3, 0xa1, 0x51, 0x2c, 0x0c, 0x1d, 0x64, 0x7a, 0x43, 0x4e, 0xab, 0x31, 0x89, + 0x06, 0x66, 0x92, 0xef, 0x6d, 0x43, 0xc1, 0x62, 0xb1, 0x07, 0x6e, 0x84, 0x8d, 0x48, 0xa5, 0x5c, + 0x0b, 0x1f, 0xaa, 0x06, 0x82, 0x6c, 0xaa, 0x31, 0x29, 0x6f, 0x05, 0xe9, 0xe8, 0xcb, 0x70, 0xa6, + 0x57, 0x22, 0x37, 0xee, 0xd9, 0x81, 0x91, 0x2b, 0x5c, 0x6e, 0xaf, 0x8d, 0x23, 0x6b, 0x20, 0x11, + 0x7d, 0x06, 0xa6, 0x58, 0xab, 0x21, 0x2a, 0x32, 0x6c, 0xdb, 0xab, 0xaf, 0xc1, 0x58, 0x7e, 0xd2, + 0xdf, 0x1c, 0xbe, 0xe9, 0x2e, 0xb7, 0xcc, 0x66, 0x71, 0x6e, 0x68, 0x7f, 0x1b, 0x0c, 0x22, 0x20, + 0xfd, 0xcd, 0xf1, 0xa9, 0xa4, 0xdd, 0x2d, 0x96, 0xc2, 0xf7, 0x68, 0xcf, 0x0c, 0x6d, 0xf7, 0x90, + 0xbd, 0xf8, 0x2a, 0x0d, 0x20, 0xf4, 0xc9, 0xa4, 0x68, 0x16, 0x3b, 0x2d, 0x2e, 0xd3, 0x6e, 0x7c, + 0x76, 0x68, 0xd1, 0x06, 0x4f, 0xc0, 0x93, 0xa2, 0x59, 0x3e, 0x15, 0x3d, 0x04, 0x91, 0x9f, 0x08, + 0xf5, 0xd7, 0xc6, 0xce, 0x0d, 0xdd, 0x15, 0x09, 0xdf, 0xd4, 0xac, 0xc6, 0xa4, 0x19, 0xb5, 0x37, + 0x85, 0x0c, 0x16, 0x54, 0x9e, 0xac, 0xfa, 0x47, 0x79, 0x8b, 0xc5, 0xa1, 0x83, 0xc5, 0x90, 0xc3, + 0xdf, 0x64, 0xb0, 0x50, 0xfb, 0x92, 0x88, 0x19, 0xeb, 0x86, 0xee, 0xd0, 0x81, 0x7d, 0x7e, 0xa8, + 0x19, 0xf7, 0xde, 0xd7, 0x43, 0xcc, 0x58, 0x67, 0x14, 0x62, 0xc6, 0x0e, 0xdf, 0xc0, 0xe7, 0xcd, + 0xf1, 0xfc, 0x50, 0x33, 0x0e, 0xdb, 0xe9, 0x27, 0x66, 0xec, 0x04, 0xe9, 0xc4, 0x8c, 0xd9, 0x00, + 0xd1, 0x27, 0xf7, 0x85, 0xa1, 0x66, 0x3c, 0xf4, 0x2c, 0x11, 0x31, 0x63, 0x65, 0x20, 0x11, 0xad, + 0x01, 0x30, 0x8f, 0x48, 0x37, 0xf6, 0xcc, 0xe2, 0xc2, 0xd0, 0xf9, 0xa7, 0x7f, 0x0b, 0x9f, 0xcc, + 0x3f, 0x2d, 0x97, 0x46, 0x06, 0x32, 0xea, 0x63, 0xcb, 0x74, 0x21, 0xbe, 0xb8, 0x38, 0x74, 0x20, + 0x1b, 0x58, 0x8f, 0x27, 0x03, 0xd9, 0x81, 0x47, 0x24, 0x13, 0x19, 0x5b, 0xbe, 0x2a, 0x2e, 0x8d, + 0x59, 0x26, 0x09, 0x4c, 0x64, 0x8c, 0x03, 0xad, 0x40, 0x86, 0x78, 0x0a, 0x47, 0x74, 0x18, 0xba, + 0x38, 0xd4, 0xbb, 0xed, 0x8b, 0x90, 0xad, 0xc6, 0xa4, 0xf4, 0x7b, 0x9c, 0x44, 0x3e, 0xcf, 0xd6, + 0x10, 0x8a, 0xa5, 0xa1, 0x9f, 0xef, 0x59, 0x35, 0x22, 0x9f, 0x67, 0x1c, 0x48, 0x85, 0xb3, 0xac, + 0xad, 0xf8, 0xe1, 0x23, 0x8b, 0x9f, 0xcf, 0x29, 0x5e, 0xa2, 0xa2, 0x86, 0x22, 0xf2, 0xd0, 0x83, + 0x50, 0xd5, 0x98, 0x34, 0xa7, 0x0c, 0xa6, 0x92, 0x0e, 0xcf, 0xa7, 0x1e, 0x86, 0xe3, 0x8b, 0x97, + 0x87, 0x76, 0xf8, 0x90, 0x95, 0x0f, 0xd2, 0xe1, 0x95, 0x00, 0x99, 0x4d, 0x40, 0x9a, 0x6c, 0xdb, + 0x6c, 0xdb, 0xe6, 0xca, 0x88, 0x09, 0xa8, 0x0f, 0xcc, 0xb3, 0x09, 0x48, 0xab, 0x33, 0x4e, 0x22, + 0x48, 0x6d, 0x61, 0xc5, 0xe2, 0xc3, 0xec, 0xd5, 0xa1, 0x82, 0x06, 0xee, 0xc0, 0x21, 0x82, 0x54, + 0x8f, 0x48, 0x26, 0x6c, 0xcb, 0x3d, 0x4a, 0xce, 0xbd, 0xcd, 0x6b, 0x43, 0x27, 0xec, 0xd0, 0x13, + 0xef, 0x64, 0xc2, 0xb6, 0x7a, 0x12, 0xd0, 0xe7, 0x60, 0x9a, 0x9f, 0xcb, 0x2d, 0x5e, 0x1f, 0xe1, + 0x03, 0x07, 0x61, 0x35, 0xe9, 0xd7, 0x9c, 0x87, 0x8d, 0xb2, 0xec, 0x58, 0x2f, 0xab, 0xde, 0x8b, + 0x23, 0x46, 0xd9, 0x01, 0x44, 0xcb, 0x46, 0x59, 0x9f, 0x4c, 0x46, 0x59, 0x66, 0xa7, 0x7c, 0xae, + 0xbb, 0x31, 0x74, 0x94, 0x1d, 0x0c, 0xcf, 0x25, 0xa3, 0xec, 0x7b, 0x3e, 0x95, 0xd4, 0xcc, 0x66, + 0x40, 0xac, 0xf8, 0xd2, 0xd0, 0x9a, 0xf5, 0x22, 0x52, 0x52, 0x33, 0xce, 0x43, 0x9a, 0x8d, 0x45, + 0x8e, 0x31, 0x4d, 0xbf, 0x3c, 0xb4, 0xd9, 0x06, 0x70, 0x4b, 0xd5, 0xbd, 0x1f, 0x91, 0x69, 0xd8, + 0x1b, 0xa8, 0x2c, 0x7e, 0x96, 0x8a, 0x6b, 0xea, 0x95, 0xd1, 0x03, 0x55, 0xd8, 0x31, 0x31, 0x6f, + 0xa0, 0xea, 0x49, 0xa4, 0x45, 0x65, 0xc1, 0xee, 0xb4, 0x7f, 0x2f, 0x0f, 0x2f, 0x6a, 0xff, 0xf9, + 0x03, 0x5a, 0x54, 0x8f, 0xe8, 0x77, 0xa1, 0x2e, 0x3b, 0x89, 0x5a, 0xbc, 0x39, 0xba, 0x0b, 0xf5, + 0x9e, 0x88, 0xf5, 0xba, 0x10, 0x27, 0x7b, 0x73, 0xa6, 0xeb, 0x61, 0x7c, 0x6a, 0xf4, 0x9c, 0xd9, + 0xef, 0x5a, 0xb0, 0x39, 0x93, 0x5f, 0x15, 0x34, 0xcd, 0x63, 0x19, 0xef, 0x27, 0xd3, 0x33, 0xa2, + 0x78, 0x3f, 0x99, 0x3e, 0x2f, 0x16, 0xef, 0x27, 0xd3, 0x17, 0xc4, 0xf9, 0xfb, 0xc9, 0xf4, 0x73, + 0xe2, 0xf3, 0xa5, 0x1f, 0x5d, 0x80, 0xbc, 0x8b, 0xd5, 0x18, 0xf2, 0xb9, 0x1d, 0x44, 0x3e, 0x0b, + 0xc3, 0x90, 0x0f, 0x47, 0x77, 0x1c, 0xfa, 0xdc, 0x0e, 0x42, 0x9f, 0x85, 0x61, 0xd0, 0xc7, 0xe7, + 0x21, 0xd8, 0xa7, 0x31, 0x0c, 0xfb, 0xbc, 0x38, 0x01, 0xf6, 0xf1, 0x44, 0xf5, 0x83, 0x9f, 0xb5, + 0x41, 0xf0, 0x73, 0x79, 0x34, 0xf8, 0xf1, 0x44, 0x05, 0xd0, 0xcf, 0x1b, 0x7d, 0xe8, 0xe7, 0xe2, + 0x08, 0xf4, 0xe3, 0xf1, 0xbb, 0xf0, 0x67, 0x3d, 0x14, 0xfe, 0x5c, 0x1d, 0x07, 0x7f, 0x3c, 0x39, + 0x3d, 0xf8, 0xe7, 0xd5, 0x1e, 0xfc, 0xb3, 0x38, 0x14, 0xff, 0x78, 0xdc, 0x0c, 0x00, 0xbd, 0x33, + 0x1c, 0x00, 0xbd, 0x34, 0x11, 0x00, 0xf2, 0xe4, 0x0d, 0x22, 0xa0, 0xc6, 0x30, 0x04, 0xf4, 0xe2, + 0x04, 0x08, 0xc8, 0x6f, 0xb8, 0x3e, 0x08, 0x54, 0x0d, 0x83, 0x40, 0x57, 0xc6, 0x40, 0x20, 0x4f, + 0x5a, 0x10, 0x03, 0x55, 0xc3, 0x30, 0xd0, 0x95, 0x31, 0x18, 0xa8, 0x4f, 0x12, 0x03, 0x41, 0x9b, + 0xe1, 0x20, 0xe8, 0xda, 0x58, 0x10, 0xe4, 0x49, 0xeb, 0x45, 0x41, 0x37, 0x03, 0x28, 0xe8, 0x85, + 0x21, 0x28, 0xc8, 0x63, 0x25, 0x30, 0xe8, 0xf3, 0x03, 0x30, 0xa8, 0x34, 0x0a, 0x06, 0x79, 0xbc, + 0x1e, 0x0e, 0x7a, 0x6b, 0x08, 0x0e, 0xba, 0x3e, 0x1e, 0x07, 0x79, 0xc2, 0xfa, 0x80, 0x90, 0x32, + 0x12, 0x08, 0xbd, 0x32, 0x21, 0x10, 0xf2, 0xa4, 0x87, 0x21, 0xa1, 0xd7, 0x7a, 0x91, 0xd0, 0xd2, + 0x70, 0x24, 0xe4, 0x89, 0xe1, 0x50, 0x68, 0x3d, 0x14, 0x0a, 0x5d, 0x1d, 0x07, 0x85, 0xfc, 0xbe, + 0x17, 0xc4, 0x42, 0x9b, 0xe1, 0x58, 0xe8, 0xda, 0x58, 0x2c, 0xe4, 0x37, 0x7f, 0x0f, 0x18, 0x5a, + 0x0f, 0x05, 0x43, 0x57, 0xc7, 0x81, 0x21, 0xbf, 0x70, 0x41, 0x34, 0xf4, 0xf6, 0x50, 0x34, 0x74, + 0x63, 0x12, 0x34, 0xe4, 0x09, 0x1d, 0x80, 0x43, 0xef, 0x0c, 0x87, 0x43, 0x2f, 0x9d, 0xe0, 0x12, + 0xa4, 0x50, 0x3c, 0xf4, 0xf9, 0x01, 0x3c, 0x54, 0x1a, 0x85, 0x87, 0x7c, 0x7b, 0x76, 0x01, 0x91, + 0x32, 0x12, 0xbe, 0xbc, 0x32, 0x21, 0x7c, 0xf1, 0x8d, 0x2f, 0x04, 0xbf, 0x54, 0x42, 0xf0, 0xcb, + 0xe5, 0xd1, 0xf8, 0xc5, 0x9f, 0x42, 0x7c, 0x00, 0x53, 0x0d, 0x03, 0x30, 0x57, 0xc6, 0x00, 0x18, + 0x7f, 0x14, 0x0a, 0x20, 0x98, 0x37, 0xfa, 0x10, 0xcc, 0xc5, 0xb1, 0x91, 0x0a, 0x01, 0x08, 0xb3, + 0x3a, 0x08, 0x61, 0x2e, 0x8d, 0x84, 0x30, 0x9e, 0x04, 0x1f, 0xc3, 0xbc, 0xd1, 0x87, 0x61, 0x2e, + 0x8e, 0xc0, 0x30, 0x7e, 0x01, 0x38, 0x88, 0xd1, 0x46, 0x83, 0x98, 0xe5, 0x49, 0x41, 0x8c, 0x27, + 0x38, 0x14, 0xc5, 0x6c, 0x86, 0xa3, 0x98, 0x6b, 0x13, 0x6e, 0x5a, 0x0e, 0xc0, 0x98, 0x6a, 0x18, + 0x8c, 0xb9, 0x32, 0x06, 0xc6, 0x04, 0xe7, 0x10, 0x0f, 0xc7, 0x54, 0xc3, 0x70, 0xcc, 0x95, 0x31, + 0x38, 0xc6, 0x97, 0x14, 0x00, 0x32, 0x8d, 0x61, 0x40, 0xe6, 0xc5, 0x09, 0x80, 0x8c, 0x3f, 0xef, + 0xf6, 0x21, 0x99, 0x37, 0xfb, 0x91, 0x4c, 0x69, 0x14, 0x92, 0xf1, 0x7b, 0xa4, 0x0b, 0x65, 0x36, + 0xc3, 0xa1, 0xcc, 0xb5, 0xb1, 0x50, 0x26, 0x38, 0x48, 0x06, 0xb0, 0xcc, 0x7a, 0x28, 0x96, 0xb9, + 0x3a, 0x0e, 0xcb, 0xf8, 0x83, 0x64, 0x10, 0xcc, 0xbc, 0xd9, 0x0f, 0x66, 0x4a, 0xa3, 0xc0, 0x8c, + 0x5f, 0x39, 0x17, 0xcd, 0x54, 0xc3, 0xd0, 0xcc, 0x95, 0x31, 0x68, 0xc6, 0x6f, 0xbc, 0x00, 0x9c, + 0x51, 0x46, 0xc2, 0x99, 0x57, 0x26, 0x84, 0x33, 0x7d, 0x03, 0x57, 0x2f, 0x9e, 0xa9, 0x86, 0xe1, + 0x99, 0x2b, 0x63, 0xf0, 0x4c, 0xa0, 0xb0, 0x3e, 0xa0, 0xd9, 0x0c, 0x07, 0x34, 0xd7, 0xc6, 0x02, + 0x9a, 0xbe, 0xde, 0xe4, 0x22, 0x9a, 0xf5, 0x50, 0x44, 0x73, 0x75, 0x1c, 0xa2, 0xe9, 0x9b, 0xf8, + 0x26, 0x84, 0x34, 0xf7, 0x93, 0xe9, 0xe7, 0xc5, 0x17, 0x4a, 0x3f, 0x9f, 0x82, 0x54, 0xd5, 0x0d, + 0x1c, 0x0a, 0xdc, 0xa2, 0x20, 0x9c, 0xe6, 0x16, 0x05, 0xb4, 0x46, 0x7a, 0x09, 0x1d, 0x6b, 0x38, + 0xc8, 0x19, 0x71, 0x49, 0xc8, 0xe0, 0xad, 0x2b, 0x9c, 0xf5, 0x14, 0xc7, 0xaa, 0xd0, 0xab, 0x90, + 0xef, 0xda, 0xd8, 0x92, 0x3b, 0x96, 0x6e, 0x5a, 0xba, 0xc3, 0xc2, 0x6d, 0x85, 0x55, 0xf1, 0xa3, + 0xe3, 0xc5, 0xdc, 0x8e, 0x8d, 0xad, 0x6d, 0x4e, 0x97, 0x72, 0xdd, 0xc0, 0x9b, 0xfb, 0x4f, 0x09, + 0x53, 0x93, 0xff, 0x53, 0xc2, 0x5b, 0x20, 0x5a, 0x58, 0xd1, 0x7a, 0x66, 0x7d, 0x76, 0x3d, 0x41, + 0x78, 0x3b, 0xd1, 0xb8, 0x72, 0x37, 0x27, 0xbd, 0xa6, 0x60, 0xc6, 0xea, 0x25, 0xa2, 0x5b, 0x70, + 0xb6, 0xad, 0x1c, 0xd2, 0x60, 0x2b, 0xd9, 0x75, 0xa4, 0x68, 0x00, 0x55, 0x9a, 0xc6, 0xf9, 0xa1, + 0xb6, 0x72, 0x48, 0xff, 0x76, 0x81, 0x25, 0xd1, 0x0b, 0x97, 0xaf, 0x40, 0x41, 0xd3, 0x6d, 0x47, + 0x37, 0x54, 0xf7, 0x9e, 0x35, 0x76, 0x8f, 0x41, 0xde, 0xa5, 0xb2, 0xfb, 0xce, 0x6e, 0xc0, 0x2c, + 0x8f, 0xa8, 0xf4, 0xff, 0x88, 0x81, 0x42, 0x86, 0x34, 0x29, 0x05, 0x49, 0xf0, 0xff, 0x81, 0xa3, + 0x0c, 0x33, 0x4d, 0xc5, 0xc1, 0x07, 0xca, 0x91, 0xec, 0x86, 0xb6, 0x67, 0xe9, 0xb5, 0x45, 0xcf, + 0x3d, 0x3b, 0x5e, 0xcc, 0xdf, 0x63, 0x49, 0x03, 0x11, 0xee, 0xf9, 0x66, 0x20, 0x41, 0x43, 0x2b, + 0x90, 0xa3, 0x17, 0xa9, 0x9a, 0xec, 0xbe, 0x5e, 0x0e, 0x04, 0x86, 0x6d, 0x47, 0xf1, 0x5b, 0x7d, + 0x25, 0x7a, 0xf9, 0xaa, 0x7b, 0xc5, 0xef, 0x35, 0x98, 0x51, 0xec, 0x23, 0x43, 0xa5, 0x1a, 0xc6, + 0x86, 0xdd, 0xb5, 0x29, 0x12, 0x48, 0x4b, 0x05, 0x4a, 0x2e, 0xbb, 0x54, 0xf4, 0x1a, 0x5c, 0xd0, + 0x30, 0x71, 0x6d, 0x98, 0xff, 0xe0, 0x98, 0xa6, 0x6c, 0xb6, 0x34, 0x99, 0x9e, 0x51, 0xa6, 0x28, + 0x20, 0x2d, 0x9d, 0xa5, 0x19, 0xa8, 0xe7, 0xd0, 0x30, 0xcd, 0xad, 0x96, 0x56, 0x21, 0x89, 0xfc, + 0x56, 0xb6, 0xdf, 0x14, 0x20, 0xd7, 0x13, 0xa0, 0xfc, 0x46, 0xdf, 0x7e, 0xed, 0x85, 0x70, 0xfc, + 0x32, 0x2c, 0xea, 0x2e, 0xcd, 0xdb, 0xce, 0x8d, 0x04, 0x5a, 0x1c, 0xee, 0xff, 0xd2, 0x15, 0x04, + 0x37, 0x4a, 0xc0, 0x65, 0x7b, 0x3d, 0xf9, 0xdb, 0xef, 0x2f, 0xc6, 0x4a, 0x3f, 0x4b, 0x40, 0xbe, + 0x37, 0x10, 0xb9, 0xd6, 0x57, 0xae, 0xb0, 0xf1, 0xa5, 0x87, 0x63, 0x79, 0xc4, 0x25, 0x3e, 0x19, + 0xff, 0xe2, 0x56, 0x56, 0xcc, 0xa5, 0x11, 0xbb, 0xd2, 0xc1, 0x72, 0xfa, 0x8c, 0xf3, 0xdf, 0x8b, + 0x7b, 0x63, 0xc6, 0x32, 0x4c, 0x31, 0x85, 0x0b, 0x43, 0x8f, 0x6a, 0x51, 0x9d, 0x4b, 0x2c, 0x1b, + 0x19, 0x63, 0x1a, 0xa7, 0xba, 0xa9, 0xc5, 0x23, 0x9c, 0xe2, 0xdf, 0x4d, 0xf8, 0x7d, 0x3d, 0x53, + 0x27, 0xbb, 0xaf, 0x87, 0xed, 0x3a, 0xb7, 0x5a, 0x58, 0x75, 0xf8, 0xdf, 0xd9, 0xb8, 0xff, 0x61, + 0x72, 0xb9, 0x5f, 0x04, 0xff, 0xf3, 0x9b, 0x65, 0x89, 0xff, 0xf9, 0x4d, 0x20, 0x38, 0xab, 0xe0, + 0x89, 0xa0, 0x5d, 0x92, 0x85, 0xf0, 0xf1, 0xa6, 0xfe, 0x35, 0x01, 0x44, 0xda, 0x01, 0xef, 0x62, + 0xac, 0x45, 0x62, 0x85, 0x6e, 0xdc, 0x58, 0x7c, 0xe2, 0xb8, 0xb1, 0x92, 0x02, 0x05, 0xaf, 0x0c, + 0xec, 0xcf, 0x1c, 0x46, 0x5c, 0xb4, 0x73, 0xaa, 0x33, 0xbf, 0xa5, 0xdf, 0x11, 0x60, 0xce, 0xfb, + 0x46, 0xd9, 0x3b, 0x6a, 0x76, 0x9a, 0x48, 0x5e, 0x89, 0xfe, 0x51, 0x0d, 0x01, 0xc2, 0xf4, 0x1c, + 0xe8, 0x44, 0x16, 0x84, 0x78, 0x00, 0x04, 0x70, 0x80, 0xad, 0x35, 0xea, 0xf4, 0x2f, 0x6c, 0xd8, + 0xb3, 0x5d, 0xba, 0x1b, 0xd0, 0x00, 0x35, 0x56, 0x52, 0xcd, 0x89, 0xac, 0xda, 0xad, 0x26, 0xcd, + 0x5c, 0xfa, 0x81, 0x10, 0x14, 0xf4, 0x84, 0x38, 0x56, 0x77, 0x20, 0xf1, 0x44, 0x69, 0x8d, 0x8a, + 0xff, 0xe8, 0x51, 0xbd, 0x44, 0x72, 0xa3, 0xbb, 0x3d, 0x27, 0xf4, 0xe2, 0xc3, 0x9d, 0x80, 0x41, + 0x95, 0x06, 0x4f, 0xf2, 0xa1, 0xcf, 0xb8, 0xb5, 0x48, 0x8c, 0xff, 0x7c, 0xb0, 0x93, 0xbe, 0x9e, + 0xfc, 0xe0, 0xfd, 0x45, 0xe1, 0x46, 0x1d, 0xe6, 0x42, 0xa6, 0x2f, 0x54, 0x00, 0x08, 0xdc, 0xa5, + 0xcb, 0xff, 0x27, 0x67, 0x65, 0x4d, 0xde, 0xd9, 0x2c, 0x6f, 0x6d, 0x6c, 0xd4, 0x1a, 0x8d, 0xca, + 0x9a, 0x28, 0x20, 0x11, 0x72, 0x3d, 0x37, 0xf1, 0xf2, 0xbf, 0xc7, 0xb9, 0xf1, 0xff, 0x00, 0xfc, + 0x3b, 0xb4, 0x89, 0xac, 0xf5, 0xca, 0x23, 0xf9, 0xe1, 0xca, 0x83, 0x9d, 0x4a, 0x5d, 0x8c, 0x21, + 0x04, 0x85, 0xd5, 0x95, 0x46, 0xb9, 0x2a, 0x4b, 0x95, 0xfa, 0xf6, 0xd6, 0x66, 0xbd, 0x22, 0x0a, + 0x9c, 0x6f, 0x0d, 0x72, 0xc1, 0xb3, 0x8c, 0x68, 0x0e, 0x66, 0xca, 0xd5, 0x4a, 0x79, 0x5d, 0x7e, + 0x58, 0x5b, 0x91, 0xdf, 0xda, 0xa9, 0xec, 0x54, 0xc4, 0x18, 0x2d, 0x1a, 0x25, 0xde, 0xdd, 0x79, + 0xf0, 0x40, 0x14, 0xd0, 0x0c, 0x64, 0xd9, 0x3b, 0xbd, 0xb5, 0x57, 0x8c, 0xdf, 0xd8, 0x80, 0x6c, + 0xe0, 0xc2, 0x20, 0xf2, 0xb9, 0xed, 0x9d, 0x7a, 0x55, 0x6e, 0xd4, 0x36, 0x2a, 0xf5, 0xc6, 0xca, + 0xc6, 0x36, 0x93, 0x41, 0x69, 0x2b, 0xab, 0x5b, 0x52, 0x43, 0x14, 0xbc, 0xf7, 0xc6, 0xd6, 0x4e, + 0xb9, 0xea, 0xfd, 0xcb, 0x4f, 0x32, 0x9d, 0x10, 0x13, 0x37, 0x4c, 0x38, 0x1b, 0x7a, 0x38, 0x10, + 0x65, 0x61, 0x7a, 0xc7, 0xa0, 0x57, 0x9f, 0x88, 0x31, 0x94, 0x0f, 0x9c, 0x0f, 0x14, 0x05, 0x94, + 0x66, 0xa7, 0xc0, 0xc4, 0x38, 0x4a, 0x41, 0xbc, 0x7e, 0x47, 0x4c, 0x90, 0x62, 0x06, 0x0e, 0xd9, + 0x89, 0x49, 0x94, 0xe1, 0x67, 0x93, 0xc4, 0x29, 0x94, 0xf3, 0x0f, 0x07, 0x89, 0xa9, 0x1b, 0x17, + 0x21, 0x70, 0x76, 0x02, 0x01, 0xa4, 0x1e, 0x28, 0x0e, 0xb6, 0x1d, 0x31, 0x86, 0xa6, 0x21, 0xb1, + 0xd2, 0x6a, 0x89, 0xc2, 0xed, 0x3f, 0x15, 0x20, 0xed, 0x5e, 0xd8, 0x8a, 0x1e, 0xc0, 0x14, 0xc3, + 0xc6, 0x8b, 0xc3, 0xa7, 0x0c, 0x3a, 0xea, 0xcc, 0x2f, 0x8d, 0x9b, 0x53, 0x4a, 0x31, 0xf4, 0x36, + 0xff, 0xc3, 0x2e, 0x62, 0x2f, 0xe8, 0xd2, 0x28, 0x6b, 0x72, 0xa5, 0x8e, 0x36, 0x39, 0xd2, 0x43, + 0x4a, 0xb1, 0x4f, 0x09, 0xab, 0x2f, 0x7e, 0xf0, 0xcf, 0x0b, 0xb1, 0x0f, 0x9e, 0x2d, 0x08, 0x1f, + 0x3e, 0x5b, 0x10, 0x7e, 0xfc, 0x6c, 0x41, 0xf8, 0xa7, 0x67, 0x0b, 0xc2, 0x6f, 0xfc, 0x64, 0x21, + 0xf6, 0xe1, 0x4f, 0x16, 0x62, 0x3f, 0xfe, 0xc9, 0x42, 0xec, 0x9d, 0x69, 0xce, 0xbd, 0x9b, 0xa2, + 0xff, 0x1d, 0x76, 0xe7, 0xbf, 0x03, 0x00, 0x00, 0xff, 0xff, 0x2b, 0xd1, 0x54, 0x3e, 0x40, 0x6d, + 0x00, 0x00, } diff --git a/pkg/roachpb/api.proto b/pkg/roachpb/api.proto index 08749f70dcff..2884d677ea17 100644 --- a/pkg/roachpb/api.proto +++ b/pkg/roachpb/api.proto @@ -1440,6 +1440,11 @@ message AddSSTableRequest { // shadow already existing key entries. This disallows any key slice overlap // regardless of the timestamps. bool disallow_shadowing = 3; + // MVCCStats, if set, is the MVCCStats for the contents of this SSTable and is + // used as-is during evaluation of the AddSSTable command to update the range + // MVCCStats, instead of computing the stats for the SSTable by iterating it. + // Including these stats can make the evaluation of AddSSTable much cheaper. + storage.engine.enginepb.MVCCStats mvcc_stats = 4 [(gogoproto.customname) = "MVCCStats"]; } // AddSSTableResponse is the response to a AddSSTable() operation. diff --git a/pkg/storage/batcheval/cmd_add_sstable.go b/pkg/storage/batcheval/cmd_add_sstable.go index f8fed9d34863..96dc9529cb92 100644 --- a/pkg/storage/batcheval/cmd_add_sstable.go +++ b/pkg/storage/batcheval/cmd_add_sstable.go @@ -51,12 +51,46 @@ func EvalAddSSTable( } // Verify that the keys in the sstable are within the range specified by the - // request header, verify the key-value checksums, and compute the new - // MVCCStats. - stats, err := verifySSTable( - args.Data, mvccStartKey, mvccEndKey, h.Timestamp.WallTime) + // request header, and if the request did not include pre-computed stats, + // compute the expected MVCC stats delta of ingesting the SST. + dataIter, err := engine.NewMemSSTIterator(args.Data, true) if err != nil { - return result.Result{}, errors.Wrap(err, "verifying sstable data") + return result.Result{}, err + } + defer dataIter.Close() + + // Check that the first key is in the expected range. + dataIter.Seek(engine.MVCCKey{Key: keys.MinKey}) + ok, err := dataIter.Valid() + if err != nil { + return result.Result{}, err + } else if ok { + if unsafeKey := dataIter.UnsafeKey(); unsafeKey.Less(mvccStartKey) { + return result.Result{}, errors.Errorf("first key %s not in request range [%s,%s)", + unsafeKey.Key, mvccStartKey.Key, mvccEndKey.Key) + } + } + + var stats enginepb.MVCCStats + if args.MVCCStats != nil { + stats = *args.MVCCStats + } else { + log.VEventf(ctx, 2, "computing MVCCStats for SSTable [%s,%s)", mvccStartKey.Key, mvccEndKey.Key) + + computed, err := engine.ComputeStatsGo(dataIter, mvccStartKey, mvccEndKey, h.Timestamp.WallTime) + if err != nil { + return result.Result{}, errors.Wrap(err, "computing SSTable MVCC stats") + } + stats = computed + } + + dataIter.Seek(mvccEndKey) + ok, err = dataIter.Valid() + if err != nil { + return result.Result{}, err + } else if ok { + return result.Result{}, errors.Errorf("last key %s not in request range [%s,%s)", + dataIter.UnsafeKey(), mvccStartKey.Key, mvccEndKey.Key) } // The above MVCCStats represents what is in this new SST. @@ -154,46 +188,3 @@ func checkForKeyCollisions( checkErr := engine.CheckForKeyCollisions(existingDataIter, sstIterator) return checkErr } - -func verifySSTable( - data []byte, start, end engine.MVCCKey, nowNanos int64, -) (enginepb.MVCCStats, error) { - // To verify every KV is a valid roachpb.KeyValue in the range [start, end) - // we a) pass a verify flag on the iterator so that as ComputeStatsGo calls - // Next, we're also verifying each KV pair. We explicitly check the first key - // is >= start and then that we do not find a key after end. - dataIter, err := engine.NewMemSSTIterator(data, true) - if err != nil { - return enginepb.MVCCStats{}, err - } - defer dataIter.Close() - - // Check that the first key is in the expected range. - dataIter.Seek(engine.MVCCKey{Key: keys.MinKey}) - ok, err := dataIter.Valid() - if err != nil { - return enginepb.MVCCStats{}, err - } else if ok { - if unsafeKey := dataIter.UnsafeKey(); unsafeKey.Less(start) { - return enginepb.MVCCStats{}, errors.Errorf("first key %s not in request range [%s,%s)", - unsafeKey.Key, start.Key, end.Key) - } - } - - stats, err := engine.ComputeStatsGo(dataIter, start, end, nowNanos) - if err != nil { - return stats, err - } - - dataIter.Seek(end) - ok, err = dataIter.Valid() - if err != nil { - return enginepb.MVCCStats{}, err - } else if ok { - if unsafeKey := dataIter.UnsafeKey(); !unsafeKey.Less(end) { - return enginepb.MVCCStats{}, errors.Errorf("last key %s not in request range [%s,%s)", - unsafeKey.Key, start.Key, end.Key) - } - } - return stats, nil -} diff --git a/pkg/storage/batcheval/cmd_add_sstable_test.go b/pkg/storage/batcheval/cmd_add_sstable_test.go index 111f383d226a..ed229954d1fa 100644 --- a/pkg/storage/batcheval/cmd_add_sstable_test.go +++ b/pkg/storage/batcheval/cmd_add_sstable_test.go @@ -88,13 +88,13 @@ func runTestDBAddSSTable(ctx context.Context, t *testing.T, db *client.DB, store // Key is before the range in the request span. if err := db.AddSSTable( - ctx, "d", "e", data, false, /* disallowShadowing */ + ctx, "d", "e", data, false /* disallowShadowing */, nil, /* stats */ ); !testutils.IsError(err, "not in request range") { t.Fatalf("expected request range error got: %+v", err) } // Key is after the range in the request span. if err := db.AddSSTable( - ctx, "a", "b", data, false, /* disallowShadowing */ + ctx, "a", "b", data, false /* disallowShadowing */, nil, /* stats */ ); !testutils.IsError(err, "not in request range") { t.Fatalf("expected request range error got: %+v", err) } @@ -102,7 +102,7 @@ func runTestDBAddSSTable(ctx context.Context, t *testing.T, db *client.DB, store // Do an initial ingest. ingestCtx, collect, cancel := tracing.ContextWithRecordingSpan(ctx, "test-recording") defer cancel() - if err := db.AddSSTable(ingestCtx, "b", "c", data, false /* disallowShadowing */); err != nil { + if err := db.AddSSTable(ingestCtx, "b", "c", data, false /* disallowShadowing */, nil /* stats */); err != nil { t.Fatalf("%+v", err) } formatted := tracing.FormatRecordedSpans(collect()) @@ -143,7 +143,7 @@ func runTestDBAddSSTable(ctx context.Context, t *testing.T, db *client.DB, store t.Fatalf("%+v", err) } - if err := db.AddSSTable(ctx, "b", "c", data, false /* disallowShadowing */); err != nil { + if err := db.AddSSTable(ctx, "b", "c", data, false /* disallowShadowing */, nil /* stats */); err != nil { t.Fatalf("%+v", err) } if r, err := db.Get(ctx, "bb"); err != nil { @@ -178,7 +178,7 @@ func runTestDBAddSSTable(ctx context.Context, t *testing.T, db *client.DB, store ingestCtx, collect, cancel := tracing.ContextWithRecordingSpan(ctx, "test-recording") defer cancel() - if err := db.AddSSTable(ingestCtx, "b", "c", data, false /* disallowShadowing */); err != nil { + if err := db.AddSSTable(ingestCtx, "b", "c", data, false /* disallowShadowing */, nil /* stats */); err != nil { t.Fatalf("%+v", err) } if err := testutils.MatchInOrder(tracing.FormatRecordedSpans(collect()), @@ -223,7 +223,7 @@ func runTestDBAddSSTable(ctx context.Context, t *testing.T, db *client.DB, store t.Fatalf("%+v", err) } - if err := db.AddSSTable(ctx, "b", "c", data, false /* disallowShadowing */); !testutils.IsError(err, "invalid checksum") { + if err := db.AddSSTable(ctx, "b", "c", data, false /* disallowShadowing */, nil /* stats */); !testutils.IsError(err, "invalid checksum") { t.Fatalf("expected 'invalid checksum' error got: %+v", err) } } @@ -325,13 +325,13 @@ func TestAddSSTableMVCCStats(t *testing.T) { return beforeStats }() - sstBytes := func() []byte { + mkSST := func(kvs []engine.MVCCKeyValue) []byte { sst, err := engine.MakeRocksDBSstFileWriter() if err != nil { t.Fatalf("%+v", err) } defer sst.Close() - for _, kv := range sstKVs { + for _, kv := range kvs { if err := sst.Add(kv); err != nil { t.Fatalf("%+v", err) } @@ -341,7 +341,9 @@ func TestAddSSTableMVCCStats(t *testing.T) { t.Fatalf("%+v", err) } return sstBytes - }() + } + + sstBytes := mkSST(sstKVs) cArgs := batcheval.CommandArgs{ Header: roachpb.Header{ @@ -353,8 +355,7 @@ func TestAddSSTableMVCCStats(t *testing.T) { }, Stats: &enginepb.MVCCStats{}, } - _, err := batcheval.EvalAddSSTable(ctx, e, cArgs, nil) - if err != nil { + if _, err := batcheval.EvalAddSSTable(ctx, e, cArgs, nil); err != nil { t.Fatalf("%+v", err) } @@ -382,6 +383,27 @@ func TestAddSSTableMVCCStats(t *testing.T) { if !afterStats.Equal(evaledStats) { t.Errorf("mvcc stats mismatch: diff(expected, actual): %s", pretty.Diff(afterStats, evaledStats)) } + + cArgsWithStats := batcheval.CommandArgs{ + Header: roachpb.Header{Timestamp: hlc.Timestamp{WallTime: 7}}, + Args: &roachpb.AddSSTableRequest{ + RequestHeader: roachpb.RequestHeader{Key: keys.MinKey, EndKey: keys.MaxKey}, + Data: mkSST([]engine.MVCCKeyValue{{ + Key: engine.MVCCKey{Key: roachpb.Key("zzzzzzz"), Timestamp: ts}, + Value: roachpb.MakeValueFromBytes([]byte("zzz")).RawBytes, + }}), + MVCCStats: &enginepb.MVCCStats{KeyCount: 10}, + }, + Stats: &enginepb.MVCCStats{}, + } + if _, err := batcheval.EvalAddSSTable(ctx, e, cArgsWithStats, nil); err != nil { + t.Fatalf("%+v", err) + } + expected := enginepb.MVCCStats{ContainsEstimates: true, KeyCount: 10} + if got := *cArgsWithStats.Stats; got != expected { + t.Fatalf("expected %v got %v", expected, got) + } + } func TestAddSSTableDisallowShadowing(t *testing.T) { diff --git a/pkg/storage/bulk/sst_batcher.go b/pkg/storage/bulk/sst_batcher.go index e97d66ebb644..a70372f2c91e 100644 --- a/pkg/storage/bulk/sst_batcher.go +++ b/pkg/storage/bulk/sst_batcher.go @@ -18,9 +18,11 @@ import ( "github.com/cockroachdb/cockroach/pkg/kv" "github.com/cockroachdb/cockroach/pkg/roachpb" "github.com/cockroachdb/cockroach/pkg/storage/engine" + "github.com/cockroachdb/cockroach/pkg/storage/engine/enginepb" "github.com/cockroachdb/cockroach/pkg/storage/storagebase" "github.com/cockroachdb/cockroach/pkg/util/humanizeutil" "github.com/cockroachdb/cockroach/pkg/util/log" + "github.com/cockroachdb/cockroach/pkg/util/timeutil" "github.com/pkg/errors" ) @@ -200,13 +202,16 @@ func (b *SSTBatcher) GetSummary() roachpb.BulkOpSummary { } type sender interface { - AddSSTable(ctx context.Context, begin, end interface{}, data []byte, disallowShadowing bool) error + AddSSTable( + ctx context.Context, begin, end interface{}, data []byte, disallowShadowing bool, stats *enginepb.MVCCStats, + ) error } type sstSpan struct { start, end roachpb.Key sstBytes []byte disallowShadowing bool + stats enginepb.MVCCStats } // AddSSTable retries db.AddSSTable if retryable errors occur, including if the @@ -215,14 +220,23 @@ type sstSpan struct { func AddSSTable( ctx context.Context, db sender, start, end roachpb.Key, sstBytes []byte, disallowShadowing bool, ) error { - work := []*sstSpan{{start: start, end: end, sstBytes: sstBytes, disallowShadowing: disallowShadowing}} - // Create an iterator that iterates over the top level SST to produce all the splits. - var iter engine.SimpleIterator - defer func() { - if iter != nil { - iter.Close() - } - }() + // Create an iterator that iterates over the top level SST for use in stats + // computation and to produce split ssts if needed for retries. + iter, err := engine.NewMemSSTIterator(sstBytes, true) + if err != nil { + return err + } + defer iter.Close() + + now := timeutil.Now().UnixNano() + stats, err := engine.ComputeStatsGo( + iter, engine.MVCCKey{Key: start}, engine.MVCCKey{Key: end}, now, + ) + if err != nil { + return errors.Wrapf(err, "computing stats for SST [%s, %s)", start, end) + } + + work := []*sstSpan{{start: start, end: end, sstBytes: sstBytes, stats: stats}} const maxAddSSTableRetries = 10 for len(work) > 0 { item := work[0] @@ -230,26 +244,30 @@ func AddSSTable( if err := func() error { var err error for i := 0; i < maxAddSSTableRetries; i++ { - log.VEventf(ctx, 2, "sending %s AddSSTable [%s,%s)", sz(len(sstBytes)), start, end) + log.VEventf(ctx, 2, "sending %s AddSSTable [%s,%s)", sz(len(item.sstBytes)), start, end) // This will fail if the range has split but we'll check for that below. - err = db.AddSSTable(ctx, item.start, item.end, item.sstBytes, item.disallowShadowing) + err = db.AddSSTable(ctx, item.start, item.end, item.sstBytes, item.disallowShadowing, &item.stats) if err == nil { return nil } // This range has split -- we need to split the SST to try again. if m, ok := errors.Cause(err).(*roachpb.RangeKeyMismatchError); ok { - if iter == nil { - iter, err = engine.NewMemSSTIterator(sstBytes, false) - if err != nil { - return err - } - } split := m.MismatchedRange.EndKey.AsRawKey() log.Infof(ctx, "SSTable cannot be added spanning range bounds %v, retrying...", split) left, right, err := createSplitSSTable(ctx, db, item.start, split, item.disallowShadowing, iter) if err != nil { return err } + + right.stats, err = engine.ComputeStatsGo( + iter, engine.MVCCKey{Key: right.start}, engine.MVCCKey{Key: right.end}, now, + ) + if err != nil { + return err + } + left.stats = item.stats + left.stats.Subtract(right.stats) + // Add more work. work = append([]*sstSpan{left, right}, work...) return nil diff --git a/pkg/storage/bulk/sst_batcher_test.go b/pkg/storage/bulk/sst_batcher_test.go index 564d3a9bf809..9df9fa4025ab 100644 --- a/pkg/storage/bulk/sst_batcher_test.go +++ b/pkg/storage/bulk/sst_batcher_test.go @@ -25,6 +25,7 @@ import ( "github.com/cockroachdb/cockroach/pkg/roachpb" "github.com/cockroachdb/cockroach/pkg/storage/bulk" "github.com/cockroachdb/cockroach/pkg/storage/engine" + "github.com/cockroachdb/cockroach/pkg/storage/engine/enginepb" "github.com/cockroachdb/cockroach/pkg/testutils/serverutils" "github.com/cockroachdb/cockroach/pkg/util/encoding" "github.com/cockroachdb/cockroach/pkg/util/hlc" @@ -211,7 +212,11 @@ func runTestImport(t *testing.T, batchSize int64) { type mockSender func(span roachpb.Span) error func (m mockSender) AddSSTable( - ctx context.Context, begin, end interface{}, data []byte, disallowShadowing bool, + ctx context.Context, + begin, end interface{}, + data []byte, + disallowShadowing bool, + _ *enginepb.MVCCStats, ) error { return m(roachpb.Span{Key: begin.(roachpb.Key), EndKey: end.(roachpb.Key)}) } @@ -248,7 +253,7 @@ func TestAddBigSpanningSSTWithSplits(t *testing.T) { splits = append(splits, key(i)) } if err := w.Add(engine.MVCCKeyValue{ - Key: engine.MVCCKey{Key: key(i)}, + Key: engine.MVCCKey{Key: key(i), Timestamp: hlc.Timestamp{WallTime: 1}}, Value: roachpb.MakeValueFromString(string(buf)).RawBytes, }); err != nil { t.Fatal(err)