| // Code generated by protoc-gen-go. DO NOT EDIT. |
| // source: google/spanner/v1/query_plan.proto |
| |
| package spanner // import "google.golang.org/genproto/googleapis/spanner/v1" |
| |
| import proto "github.com/golang/protobuf/proto" |
| import fmt "fmt" |
| import math "math" |
| import _struct "github.com/golang/protobuf/ptypes/struct" |
| import _ "google.golang.org/genproto/googleapis/api/annotations" |
| |
| // Reference imports to suppress errors if they are not otherwise used. |
| var _ = proto.Marshal |
| var _ = fmt.Errorf |
| var _ = math.Inf |
| |
| // This is a compile-time assertion to ensure that this generated file |
| // is compatible with the proto package it is being compiled against. |
| // A compilation error at this line likely means your copy of the |
| // proto package needs to be updated. |
| const _ = proto.ProtoPackageIsVersion2 // please upgrade the proto package |
| |
| // The kind of [PlanNode][google.spanner.v1.PlanNode]. Distinguishes between the two different kinds of |
| // nodes that can appear in a query plan. |
| type PlanNode_Kind int32 |
| |
| const ( |
| // Not specified. |
| PlanNode_KIND_UNSPECIFIED PlanNode_Kind = 0 |
| // Denotes a Relational operator node in the expression tree. Relational |
| // operators represent iterative processing of rows during query execution. |
| // For example, a `TableScan` operation that reads rows from a table. |
| PlanNode_RELATIONAL PlanNode_Kind = 1 |
| // Denotes a Scalar node in the expression tree. Scalar nodes represent |
| // non-iterable entities in the query plan. For example, constants or |
| // arithmetic operators appearing inside predicate expressions or references |
| // to column names. |
| PlanNode_SCALAR PlanNode_Kind = 2 |
| ) |
| |
| var PlanNode_Kind_name = map[int32]string{ |
| 0: "KIND_UNSPECIFIED", |
| 1: "RELATIONAL", |
| 2: "SCALAR", |
| } |
| var PlanNode_Kind_value = map[string]int32{ |
| "KIND_UNSPECIFIED": 0, |
| "RELATIONAL": 1, |
| "SCALAR": 2, |
| } |
| |
| func (x PlanNode_Kind) String() string { |
| return proto.EnumName(PlanNode_Kind_name, int32(x)) |
| } |
| func (PlanNode_Kind) EnumDescriptor() ([]byte, []int) { |
| return fileDescriptor_query_plan_e20f6b3462ee8118, []int{0, 0} |
| } |
| |
| // Node information for nodes appearing in a [QueryPlan.plan_nodes][google.spanner.v1.QueryPlan.plan_nodes]. |
| type PlanNode struct { |
| // The `PlanNode`'s index in [node list][google.spanner.v1.QueryPlan.plan_nodes]. |
| Index int32 `protobuf:"varint,1,opt,name=index,proto3" json:"index,omitempty"` |
| // Used to determine the type of node. May be needed for visualizing |
| // different kinds of nodes differently. For example, If the node is a |
| // [SCALAR][google.spanner.v1.PlanNode.Kind.SCALAR] node, it will have a condensed representation |
| // which can be used to directly embed a description of the node in its |
| // parent. |
| Kind PlanNode_Kind `protobuf:"varint,2,opt,name=kind,proto3,enum=google.spanner.v1.PlanNode_Kind" json:"kind,omitempty"` |
| // The display name for the node. |
| DisplayName string `protobuf:"bytes,3,opt,name=display_name,json=displayName,proto3" json:"display_name,omitempty"` |
| // List of child node `index`es and their relationship to this parent. |
| ChildLinks []*PlanNode_ChildLink `protobuf:"bytes,4,rep,name=child_links,json=childLinks,proto3" json:"child_links,omitempty"` |
| // Condensed representation for [SCALAR][google.spanner.v1.PlanNode.Kind.SCALAR] nodes. |
| ShortRepresentation *PlanNode_ShortRepresentation `protobuf:"bytes,5,opt,name=short_representation,json=shortRepresentation,proto3" json:"short_representation,omitempty"` |
| // Attributes relevant to the node contained in a group of key-value pairs. |
| // For example, a Parameter Reference node could have the following |
| // information in its metadata: |
| // |
| // { |
| // "parameter_reference": "param1", |
| // "parameter_type": "array" |
| // } |
| Metadata *_struct.Struct `protobuf:"bytes,6,opt,name=metadata,proto3" json:"metadata,omitempty"` |
| // The execution statistics associated with the node, contained in a group of |
| // key-value pairs. Only present if the plan was returned as a result of a |
| // profile query. For example, number of executions, number of rows/time per |
| // execution etc. |
| ExecutionStats *_struct.Struct `protobuf:"bytes,7,opt,name=execution_stats,json=executionStats,proto3" json:"execution_stats,omitempty"` |
| XXX_NoUnkeyedLiteral struct{} `json:"-"` |
| XXX_unrecognized []byte `json:"-"` |
| XXX_sizecache int32 `json:"-"` |
| } |
| |
| func (m *PlanNode) Reset() { *m = PlanNode{} } |
| func (m *PlanNode) String() string { return proto.CompactTextString(m) } |
| func (*PlanNode) ProtoMessage() {} |
| func (*PlanNode) Descriptor() ([]byte, []int) { |
| return fileDescriptor_query_plan_e20f6b3462ee8118, []int{0} |
| } |
| func (m *PlanNode) XXX_Unmarshal(b []byte) error { |
| return xxx_messageInfo_PlanNode.Unmarshal(m, b) |
| } |
| func (m *PlanNode) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { |
| return xxx_messageInfo_PlanNode.Marshal(b, m, deterministic) |
| } |
| func (dst *PlanNode) XXX_Merge(src proto.Message) { |
| xxx_messageInfo_PlanNode.Merge(dst, src) |
| } |
| func (m *PlanNode) XXX_Size() int { |
| return xxx_messageInfo_PlanNode.Size(m) |
| } |
| func (m *PlanNode) XXX_DiscardUnknown() { |
| xxx_messageInfo_PlanNode.DiscardUnknown(m) |
| } |
| |
| var xxx_messageInfo_PlanNode proto.InternalMessageInfo |
| |
| func (m *PlanNode) GetIndex() int32 { |
| if m != nil { |
| return m.Index |
| } |
| return 0 |
| } |
| |
| func (m *PlanNode) GetKind() PlanNode_Kind { |
| if m != nil { |
| return m.Kind |
| } |
| return PlanNode_KIND_UNSPECIFIED |
| } |
| |
| func (m *PlanNode) GetDisplayName() string { |
| if m != nil { |
| return m.DisplayName |
| } |
| return "" |
| } |
| |
| func (m *PlanNode) GetChildLinks() []*PlanNode_ChildLink { |
| if m != nil { |
| return m.ChildLinks |
| } |
| return nil |
| } |
| |
| func (m *PlanNode) GetShortRepresentation() *PlanNode_ShortRepresentation { |
| if m != nil { |
| return m.ShortRepresentation |
| } |
| return nil |
| } |
| |
| func (m *PlanNode) GetMetadata() *_struct.Struct { |
| if m != nil { |
| return m.Metadata |
| } |
| return nil |
| } |
| |
| func (m *PlanNode) GetExecutionStats() *_struct.Struct { |
| if m != nil { |
| return m.ExecutionStats |
| } |
| return nil |
| } |
| |
| // Metadata associated with a parent-child relationship appearing in a |
| // [PlanNode][google.spanner.v1.PlanNode]. |
| type PlanNode_ChildLink struct { |
| // The node to which the link points. |
| ChildIndex int32 `protobuf:"varint,1,opt,name=child_index,json=childIndex,proto3" json:"child_index,omitempty"` |
| // The type of the link. For example, in Hash Joins this could be used to |
| // distinguish between the build child and the probe child, or in the case |
| // of the child being an output variable, to represent the tag associated |
| // with the output variable. |
| Type string `protobuf:"bytes,2,opt,name=type,proto3" json:"type,omitempty"` |
| // Only present if the child node is [SCALAR][google.spanner.v1.PlanNode.Kind.SCALAR] and corresponds |
| // to an output variable of the parent node. The field carries the name of |
| // the output variable. |
| // For example, a `TableScan` operator that reads rows from a table will |
| // have child links to the `SCALAR` nodes representing the output variables |
| // created for each column that is read by the operator. The corresponding |
| // `variable` fields will be set to the variable names assigned to the |
| // columns. |
| Variable string `protobuf:"bytes,3,opt,name=variable,proto3" json:"variable,omitempty"` |
| XXX_NoUnkeyedLiteral struct{} `json:"-"` |
| XXX_unrecognized []byte `json:"-"` |
| XXX_sizecache int32 `json:"-"` |
| } |
| |
| func (m *PlanNode_ChildLink) Reset() { *m = PlanNode_ChildLink{} } |
| func (m *PlanNode_ChildLink) String() string { return proto.CompactTextString(m) } |
| func (*PlanNode_ChildLink) ProtoMessage() {} |
| func (*PlanNode_ChildLink) Descriptor() ([]byte, []int) { |
| return fileDescriptor_query_plan_e20f6b3462ee8118, []int{0, 0} |
| } |
| func (m *PlanNode_ChildLink) XXX_Unmarshal(b []byte) error { |
| return xxx_messageInfo_PlanNode_ChildLink.Unmarshal(m, b) |
| } |
| func (m *PlanNode_ChildLink) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { |
| return xxx_messageInfo_PlanNode_ChildLink.Marshal(b, m, deterministic) |
| } |
| func (dst *PlanNode_ChildLink) XXX_Merge(src proto.Message) { |
| xxx_messageInfo_PlanNode_ChildLink.Merge(dst, src) |
| } |
| func (m *PlanNode_ChildLink) XXX_Size() int { |
| return xxx_messageInfo_PlanNode_ChildLink.Size(m) |
| } |
| func (m *PlanNode_ChildLink) XXX_DiscardUnknown() { |
| xxx_messageInfo_PlanNode_ChildLink.DiscardUnknown(m) |
| } |
| |
| var xxx_messageInfo_PlanNode_ChildLink proto.InternalMessageInfo |
| |
| func (m *PlanNode_ChildLink) GetChildIndex() int32 { |
| if m != nil { |
| return m.ChildIndex |
| } |
| return 0 |
| } |
| |
| func (m *PlanNode_ChildLink) GetType() string { |
| if m != nil { |
| return m.Type |
| } |
| return "" |
| } |
| |
| func (m *PlanNode_ChildLink) GetVariable() string { |
| if m != nil { |
| return m.Variable |
| } |
| return "" |
| } |
| |
| // Condensed representation of a node and its subtree. Only present for |
| // `SCALAR` [PlanNode(s)][google.spanner.v1.PlanNode]. |
| type PlanNode_ShortRepresentation struct { |
| // A string representation of the expression subtree rooted at this node. |
| Description string `protobuf:"bytes,1,opt,name=description,proto3" json:"description,omitempty"` |
| // A mapping of (subquery variable name) -> (subquery node id) for cases |
| // where the `description` string of this node references a `SCALAR` |
| // subquery contained in the expression subtree rooted at this node. The |
| // referenced `SCALAR` subquery may not necessarily be a direct child of |
| // this node. |
| Subqueries map[string]int32 `protobuf:"bytes,2,rep,name=subqueries,proto3" json:"subqueries,omitempty" protobuf_key:"bytes,1,opt,name=key,proto3" protobuf_val:"varint,2,opt,name=value,proto3"` |
| XXX_NoUnkeyedLiteral struct{} `json:"-"` |
| XXX_unrecognized []byte `json:"-"` |
| XXX_sizecache int32 `json:"-"` |
| } |
| |
| func (m *PlanNode_ShortRepresentation) Reset() { *m = PlanNode_ShortRepresentation{} } |
| func (m *PlanNode_ShortRepresentation) String() string { return proto.CompactTextString(m) } |
| func (*PlanNode_ShortRepresentation) ProtoMessage() {} |
| func (*PlanNode_ShortRepresentation) Descriptor() ([]byte, []int) { |
| return fileDescriptor_query_plan_e20f6b3462ee8118, []int{0, 1} |
| } |
| func (m *PlanNode_ShortRepresentation) XXX_Unmarshal(b []byte) error { |
| return xxx_messageInfo_PlanNode_ShortRepresentation.Unmarshal(m, b) |
| } |
| func (m *PlanNode_ShortRepresentation) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { |
| return xxx_messageInfo_PlanNode_ShortRepresentation.Marshal(b, m, deterministic) |
| } |
| func (dst *PlanNode_ShortRepresentation) XXX_Merge(src proto.Message) { |
| xxx_messageInfo_PlanNode_ShortRepresentation.Merge(dst, src) |
| } |
| func (m *PlanNode_ShortRepresentation) XXX_Size() int { |
| return xxx_messageInfo_PlanNode_ShortRepresentation.Size(m) |
| } |
| func (m *PlanNode_ShortRepresentation) XXX_DiscardUnknown() { |
| xxx_messageInfo_PlanNode_ShortRepresentation.DiscardUnknown(m) |
| } |
| |
| var xxx_messageInfo_PlanNode_ShortRepresentation proto.InternalMessageInfo |
| |
| func (m *PlanNode_ShortRepresentation) GetDescription() string { |
| if m != nil { |
| return m.Description |
| } |
| return "" |
| } |
| |
| func (m *PlanNode_ShortRepresentation) GetSubqueries() map[string]int32 { |
| if m != nil { |
| return m.Subqueries |
| } |
| return nil |
| } |
| |
| // Contains an ordered list of nodes appearing in the query plan. |
| type QueryPlan struct { |
| // The nodes in the query plan. Plan nodes are returned in pre-order starting |
| // with the plan root. Each [PlanNode][google.spanner.v1.PlanNode]'s `id` corresponds to its index in |
| // `plan_nodes`. |
| PlanNodes []*PlanNode `protobuf:"bytes,1,rep,name=plan_nodes,json=planNodes,proto3" json:"plan_nodes,omitempty"` |
| XXX_NoUnkeyedLiteral struct{} `json:"-"` |
| XXX_unrecognized []byte `json:"-"` |
| XXX_sizecache int32 `json:"-"` |
| } |
| |
| func (m *QueryPlan) Reset() { *m = QueryPlan{} } |
| func (m *QueryPlan) String() string { return proto.CompactTextString(m) } |
| func (*QueryPlan) ProtoMessage() {} |
| func (*QueryPlan) Descriptor() ([]byte, []int) { |
| return fileDescriptor_query_plan_e20f6b3462ee8118, []int{1} |
| } |
| func (m *QueryPlan) XXX_Unmarshal(b []byte) error { |
| return xxx_messageInfo_QueryPlan.Unmarshal(m, b) |
| } |
| func (m *QueryPlan) XXX_Marshal(b []byte, deterministic bool) ([]byte, error) { |
| return xxx_messageInfo_QueryPlan.Marshal(b, m, deterministic) |
| } |
| func (dst *QueryPlan) XXX_Merge(src proto.Message) { |
| xxx_messageInfo_QueryPlan.Merge(dst, src) |
| } |
| func (m *QueryPlan) XXX_Size() int { |
| return xxx_messageInfo_QueryPlan.Size(m) |
| } |
| func (m *QueryPlan) XXX_DiscardUnknown() { |
| xxx_messageInfo_QueryPlan.DiscardUnknown(m) |
| } |
| |
| var xxx_messageInfo_QueryPlan proto.InternalMessageInfo |
| |
| func (m *QueryPlan) GetPlanNodes() []*PlanNode { |
| if m != nil { |
| return m.PlanNodes |
| } |
| return nil |
| } |
| |
| func init() { |
| proto.RegisterType((*PlanNode)(nil), "google.spanner.v1.PlanNode") |
| proto.RegisterType((*PlanNode_ChildLink)(nil), "google.spanner.v1.PlanNode.ChildLink") |
| proto.RegisterType((*PlanNode_ShortRepresentation)(nil), "google.spanner.v1.PlanNode.ShortRepresentation") |
| proto.RegisterMapType((map[string]int32)(nil), "google.spanner.v1.PlanNode.ShortRepresentation.SubqueriesEntry") |
| proto.RegisterType((*QueryPlan)(nil), "google.spanner.v1.QueryPlan") |
| proto.RegisterEnum("google.spanner.v1.PlanNode_Kind", PlanNode_Kind_name, PlanNode_Kind_value) |
| } |
| |
| func init() { |
| proto.RegisterFile("google/spanner/v1/query_plan.proto", fileDescriptor_query_plan_e20f6b3462ee8118) |
| } |
| |
| var fileDescriptor_query_plan_e20f6b3462ee8118 = []byte{ |
| // 604 bytes of a gzipped FileDescriptorProto |
| 0x1f, 0x8b, 0x08, 0x00, 0x00, 0x00, 0x00, 0x00, 0x02, 0xff, 0x94, 0x54, 0xdd, 0x6e, 0xd3, 0x4c, |
| 0x10, 0xfd, 0x9c, 0x26, 0xf9, 0x9a, 0x09, 0x4a, 0xc3, 0xb6, 0xa8, 0x56, 0x40, 0xc2, 0x44, 0x42, |
| 0xca, 0x95, 0xad, 0xb4, 0x5c, 0x54, 0x45, 0x08, 0xd2, 0x34, 0xad, 0xa2, 0x46, 0x21, 0xac, 0xa1, |
| 0x17, 0x28, 0x92, 0xb5, 0x89, 0x97, 0x74, 0x15, 0x67, 0xd7, 0x78, 0xed, 0xa8, 0x79, 0x09, 0x6e, |
| 0x79, 0x07, 0x1e, 0x85, 0x17, 0xe0, 0x75, 0xd0, 0xae, 0x7f, 0x28, 0x14, 0x45, 0xe2, 0x6e, 0x66, |
| 0xe7, 0xcc, 0xf1, 0xce, 0x39, 0xb3, 0x86, 0xf6, 0x42, 0x88, 0x45, 0x40, 0x1d, 0x19, 0x12, 0xce, |
| 0x69, 0xe4, 0xac, 0xbb, 0xce, 0xe7, 0x84, 0x46, 0x1b, 0x2f, 0x0c, 0x08, 0xb7, 0xc3, 0x48, 0xc4, |
| 0x02, 0x3d, 0x4c, 0x31, 0x76, 0x86, 0xb1, 0xd7, 0xdd, 0xd6, 0x93, 0xac, 0x8d, 0x84, 0xcc, 0x21, |
| 0x9c, 0x8b, 0x98, 0xc4, 0x4c, 0x70, 0x99, 0x36, 0x14, 0x55, 0x9d, 0xcd, 0x92, 0x4f, 0x8e, 0x8c, |
| 0xa3, 0x64, 0x1e, 0xa7, 0xd5, 0xf6, 0x97, 0x2a, 0xec, 0x4e, 0x02, 0xc2, 0xc7, 0xc2, 0xa7, 0xe8, |
| 0x00, 0x2a, 0x8c, 0xfb, 0xf4, 0xd6, 0x34, 0x2c, 0xa3, 0x53, 0xc1, 0x69, 0x82, 0x5e, 0x40, 0x79, |
| 0xc9, 0xb8, 0x6f, 0x96, 0x2c, 0xa3, 0xd3, 0x38, 0xb2, 0xec, 0x7b, 0x17, 0xb0, 0x73, 0x02, 0xfb, |
| 0x8a, 0x71, 0x1f, 0x6b, 0x34, 0x7a, 0x06, 0x0f, 0x7c, 0x26, 0xc3, 0x80, 0x6c, 0x3c, 0x4e, 0x56, |
| 0xd4, 0xdc, 0xb1, 0x8c, 0x4e, 0x0d, 0xd7, 0xb3, 0xb3, 0x31, 0x59, 0x51, 0x74, 0x01, 0xf5, 0xf9, |
| 0x0d, 0x0b, 0x7c, 0x2f, 0x60, 0x7c, 0x29, 0xcd, 0xb2, 0xb5, 0xd3, 0xa9, 0x1f, 0x3d, 0xdf, 0xc6, |
| 0xdf, 0x57, 0xf0, 0x11, 0xe3, 0x4b, 0x0c, 0xf3, 0x3c, 0x94, 0x68, 0x06, 0x07, 0xf2, 0x46, 0x44, |
| 0xb1, 0x17, 0xd1, 0x30, 0xa2, 0x92, 0xf2, 0x54, 0x00, 0xb3, 0x62, 0x19, 0x9d, 0xfa, 0x91, 0xb3, |
| 0x8d, 0xd0, 0x55, 0x7d, 0xf8, 0xb7, 0x36, 0xbc, 0x2f, 0xef, 0x1f, 0xa2, 0x63, 0xd8, 0x5d, 0xd1, |
| 0x98, 0xf8, 0x24, 0x26, 0x66, 0x55, 0xf3, 0x1e, 0xe6, 0xbc, 0xb9, 0xb0, 0xb6, 0xab, 0x85, 0xc5, |
| 0x05, 0x10, 0xbd, 0x81, 0x3d, 0x7a, 0x4b, 0xe7, 0x89, 0x62, 0xf0, 0x64, 0x4c, 0x62, 0x69, 0xfe, |
| 0xbf, 0xbd, 0xb7, 0x51, 0xe0, 0x5d, 0x05, 0x6f, 0x4d, 0xa1, 0x56, 0xcc, 0x8c, 0x9e, 0xe6, 0x7a, |
| 0xdd, 0x35, 0x29, 0x15, 0x62, 0xa8, 0x9d, 0x42, 0x50, 0x8e, 0x37, 0x21, 0xd5, 0x4e, 0xd5, 0xb0, |
| 0x8e, 0x51, 0x0b, 0x76, 0xd7, 0x24, 0x62, 0x64, 0x16, 0xe4, 0x1e, 0x14, 0x79, 0xeb, 0x87, 0x01, |
| 0xfb, 0x7f, 0x51, 0x00, 0x59, 0x50, 0xf7, 0xa9, 0x9c, 0x47, 0x2c, 0xd4, 0x3a, 0x1a, 0x99, 0x75, |
| 0xbf, 0x8e, 0x90, 0x07, 0x20, 0x93, 0x99, 0x5a, 0x4e, 0x46, 0xa5, 0x59, 0xd2, 0xce, 0xbd, 0xfe, |
| 0x47, 0xa1, 0x6d, 0xb7, 0x60, 0x18, 0xf0, 0x38, 0xda, 0xe0, 0x3b, 0x94, 0xad, 0x57, 0xb0, 0xf7, |
| 0x47, 0x19, 0x35, 0x61, 0x67, 0x49, 0x37, 0xd9, 0x6d, 0x54, 0xa8, 0xf6, 0x75, 0x4d, 0x82, 0x24, |
| 0x1d, 0xb8, 0x82, 0xd3, 0xe4, 0xb4, 0x74, 0x62, 0xb4, 0x4f, 0xa0, 0xac, 0x76, 0x11, 0x1d, 0x40, |
| 0xf3, 0x6a, 0x38, 0x3e, 0xf7, 0x3e, 0x8c, 0xdd, 0xc9, 0xa0, 0x3f, 0xbc, 0x18, 0x0e, 0xce, 0x9b, |
| 0xff, 0xa1, 0x06, 0x00, 0x1e, 0x8c, 0x7a, 0xef, 0x87, 0x6f, 0xc7, 0xbd, 0x51, 0xd3, 0x40, 0x00, |
| 0x55, 0xb7, 0xdf, 0x1b, 0xf5, 0x70, 0xb3, 0xd4, 0xbe, 0x84, 0xda, 0x3b, 0xf5, 0xe6, 0xd4, 0xcd, |
| 0xd1, 0x29, 0x80, 0x7a, 0x7a, 0x1e, 0x17, 0x3e, 0x95, 0xa6, 0xa1, 0xc7, 0x7c, 0xbc, 0x65, 0x4c, |
| 0x5c, 0x0b, 0xb3, 0x48, 0x9e, 0x7d, 0x35, 0xe0, 0xd1, 0x5c, 0xac, 0xee, 0xa3, 0xcf, 0x1a, 0xc5, |
| 0x07, 0x26, 0xca, 0xfe, 0x89, 0xf1, 0xf1, 0x24, 0x03, 0x2d, 0x44, 0x40, 0xf8, 0xc2, 0x16, 0xd1, |
| 0xc2, 0x59, 0x50, 0xae, 0x97, 0xc3, 0x49, 0x4b, 0x24, 0x64, 0xf2, 0xce, 0x7f, 0xe1, 0x65, 0x16, |
| 0x7e, 0x2b, 0x1d, 0x5e, 0xa6, 0xad, 0xfd, 0x40, 0x24, 0xbe, 0xed, 0x66, 0x5f, 0xb9, 0xee, 0x7e, |
| 0xcf, 0x2b, 0x53, 0x5d, 0x99, 0x66, 0x95, 0xe9, 0x75, 0x77, 0x56, 0xd5, 0xc4, 0xc7, 0x3f, 0x03, |
| 0x00, 0x00, 0xff, 0xff, 0x53, 0xdb, 0x51, 0xa6, 0x6f, 0x04, 0x00, 0x00, |
| } |