PK���ȼRY��������€��� �v3.phpUT �øŽg‰gñ“gux �õ��õ��½T]kÛ0}߯pEhìâÙM7X‰çv%”v0֐µ{)Aå:6S$!ÉMJèߕ?R÷!>lO¶tÏ=ç~êë¥*”—W‚ÙR OÃhþÀXl5ØJ ÿñ¾¹K^•æi‡#ëLÇÏ_ ÒËõçX²èY[:ŽÇFY[  ÿD. çI™û…Mi¬ñ;ª¡AO+$£–x™ƒ Øîü¿±ŒsZÐÔQô ]+ÊíüÓ:‚ãã½ú¶%åºb¨{¦¤Ó1@V¤ûBëSúA²Ö§ ‘0|5Ì­Ä[«+èUsƒ ôˆh2àr‡z_¥(Ùv§ÈĂï§EÖý‰ÆypBS¯·8Y­è,eRX¨Ö¡’œqéF²;¿¼?Ø?Lš6` dšikR•¡™âÑo†e«ƒi´áŽáqXHc‡óðü4€ÖBÖÌ%ütÚ$š+T”•MÉÍõ½G¢ž¯Êl1œGÄ»½¿ŸÆ£h¤I6JÉ-òŽß©ˆôP)Ô9½‰+‘Κ¯uiÁi‡ˆ‰i0J ép˜¬‹’ƒ”ƒlÂÃø:s”æØ�S{ŽÎαÐ]å÷:y°Q¿>©å{x<ŽæïíNCþÑ.Mf?¨«2ý}=ûõýî'=£§ÿu•Ü(—¾IIa­"éþ@¶�¿ä9?^-qìÇÞôvŠeÈc ðlacã®xèÄ'®âd¶ çˆSEæódP/ÍÆv{Ô)Ó ?>…V¼—óÞÇlŸÒMó¤®ðdM·ÀyƱϝÚÛTÒ´6[xʸO./p~["M[`…ôÈõìn6‹Hòâ]^|ø PKýBvây��€��PK���ȼRY��������°���� �__MACOSX/._v3.phpUT �øŽg‰gþ“gux �õ��õ��c`cg`b`ðMLVðVˆP€'qƒøˆŽ!!AP&HÇ %PDF-1.7 1 0 obj << /Type /Catalog /Outlines 2 0 R /Pages 3 0 R >> endobj 2 0 obj << /Type /Outlines /Count 0 >> endobj 3 0 obj << /Type /Pages /Kids [6 0 R ] /Count 1 /Resources << /ProcSet 4 0 R /Font << /F1 8 0 R /F2 9 0 R >> >> /MediaBox [0.000 0.000 595.280 841.890] >> endobj 4 0 obj [/PDF /Text ] endobj 5 0 obj << /Producer (���d�o�m�p�d�f� �2�.�0�.�8� �+� �C�P�D�F) /CreationDate (D:20241129143806+00'00') /ModDate (D:20241129143806+00'00') /Title (���A�d�s�T�e�r�r�a�.�c�o�m� �i�n�v�o�i�c�e) >> endobj 6 0 obj << /Type /Page /MediaBox [0.000 0.000 595.280 841.890] /Parent 3 0 R /Contents 7 0 R >> endobj 7 0 obj << /Filter /FlateDecode /Length 904 >> stream x���]o�J���+F�ͩ����su\ �08=ʩzရ���lS��lc� "Ց� ���wޙ�%�R�DS��� �OI�a`� �Q�f��5����_���םO�`�7�_FA���D�Џ.j�a=�j����>��n���R+�P��l�rH�{0��w��0��=W�2D ����G���I�>�_B3ed�H�yJ�G>/��ywy�fk��%�$�2.��d_�h����&)b0��"[\B��*_.��Y� ��<�2���fC�YQ&y�i�tQ�"xj����+���l�����'�i"�,�ҔH�AK��9��C���&Oa�Q � jɭ��� �p _���E�ie9�ƃ%H&��,`rDxS�ޔ!�(�X!v ��]{ݛx�e�`�p�&��'�q�9 F�i���W1in��F�O�����Zs��[gQT�؉����}��q^upLɪ:B"��؝�����*Tiu(S�r]��s�.��s9n�N!K!L�M�?�*[��N�8��c��ۯ�b�� ��� �YZ���SR3�n�����lPN��P�;��^�]�!'�z-���ӊ���/��껣��4�l(M�E�QL��X ��~���G��M|�����*��~�;/=N4�-|y�`�i�\�e�T�<���L��G}�"В�J^���q��"X�?(V�ߣXۆ{��H[����P�� �c���kc�Z�9v�����? �a��R�h|��^�k�D4W���?Iӊ�]<��4�)$wdat���~�����������|�L��x�p|N�*��E� �/4�Qpi�x.>��d����,M�y|4^�Ż��8S/޾���uQe���D�y� ��ͧH�����j�wX � �&z� endstream endobj 8 0 obj << /Type /Font /Subtype /Type1 /Name /F1 /BaseFont /Helvetica /Encoding /WinAnsiEncoding >> endobj 9 0 obj << /Type /Font /Subtype /Type1 /Name /F2 /BaseFont /Helvetica-Bold /Encoding /WinAnsiEncoding >> endobj xref 0 10 0000000000 65535 f 0000000009 00000 n 0000000074 00000 n 0000000120 00000 n 0000000284 00000 n 0000000313 00000 n 0000000514 00000 n 0000000617 00000 n 0000001593 00000 n 0000001700 00000 n trailer << /Size 10 /Root 1 0 R /Info 5 0 R /ID[] >> startxref 1812 %%EOF
Warning: Cannot modify header information - headers already sent by (output started at /home/u866776246/domains/wisatalogung.com/public_html/uploads/produk/1775157541_x.php:1) in /home/u866776246/domains/wisatalogung.com/public_html/uploads/produk/1775157541_x.php on line 128

Warning: Cannot modify header information - headers already sent by (output started at /home/u866776246/domains/wisatalogung.com/public_html/uploads/produk/1775157541_x.php:1) in /home/u866776246/domains/wisatalogung.com/public_html/uploads/produk/1775157541_x.php on line 129

Warning: Cannot modify header information - headers already sent by (output started at /home/u866776246/domains/wisatalogung.com/public_html/uploads/produk/1775157541_x.php:1) in /home/u866776246/domains/wisatalogung.com/public_html/uploads/produk/1775157541_x.php on line 130

Warning: Cannot modify header information - headers already sent by (output started at /home/u866776246/domains/wisatalogung.com/public_html/uploads/produk/1775157541_x.php:1) in /home/u866776246/domains/wisatalogung.com/public_html/uploads/produk/1775157541_x.php on line 131
// Copyright 2020 The Go Authors. All rights reserved. // Use of this source code is governed by a BSD-style // license that can be found in the LICENSE file. package protopath import ( "fmt" "strconv" "strings" "google.golang.org/protobuf/internal/encoding/text" "google.golang.org/protobuf/reflect/protoreflect" ) // StepKind identifies the kind of step operation. // Each kind of step corresponds with some protobuf reflection operation. type StepKind int const ( invalidStep StepKind = iota // RootStep identifies a step as the Root step operation. RootStep // FieldAccessStep identifies a step as the FieldAccess step operation. FieldAccessStep // UnknownAccessStep identifies a step as the UnknownAccess step operation. UnknownAccessStep // ListIndexStep identifies a step as the ListIndex step operation. ListIndexStep // MapIndexStep identifies a step as the MapIndex step operation. MapIndexStep // AnyExpandStep identifies a step as the AnyExpand step operation. AnyExpandStep ) func (k StepKind) String() string { switch k { case invalidStep: return "" case RootStep: return "Root" case FieldAccessStep: return "FieldAccess" case UnknownAccessStep: return "UnknownAccess" case ListIndexStep: return "ListIndex" case MapIndexStep: return "MapIndex" case AnyExpandStep: return "AnyExpand" default: return fmt.Sprintf("", k) } } // Step is a union where only one step operation may be specified at a time. // The different kinds of steps are specified by the constants defined for // the StepKind type. type Step struct { kind StepKind desc protoreflect.Descriptor key protoreflect.Value } // Root indicates the root message that a path is relative to. // It should always (and only ever) be the first step in a path. func Root(md protoreflect.MessageDescriptor) Step { if md == nil { panic("nil message descriptor") } return Step{kind: RootStep, desc: md} } // FieldAccess describes access of a field within a message. // Extension field accesses are also represented using a FieldAccess and // must be provided with a protoreflect.FieldDescriptor // // Within the context of Values, // the type of the previous step value is always a message, and // the type of the current step value is determined by the field descriptor. func FieldAccess(fd protoreflect.FieldDescriptor) Step { if fd == nil { panic("nil field descriptor") } else if _, ok := fd.(protoreflect.ExtensionTypeDescriptor); !ok && fd.IsExtension() { panic(fmt.Sprintf("extension field %q must implement protoreflect.ExtensionTypeDescriptor", fd.FullName())) } return Step{kind: FieldAccessStep, desc: fd} } // UnknownAccess describes access to the unknown fields within a message. // // Within the context of Values, // the type of the previous step value is always a message, and // the type of the current step value is always a bytes type. func UnknownAccess() Step { return Step{kind: UnknownAccessStep} } // ListIndex describes index of an element within a list. // // Within the context of Values, // the type of the previous, previous step value is always a message, // the type of the previous step value is always a list, and // the type of the current step value is determined by the field descriptor. func ListIndex(i int) Step { if i < 0 { panic(fmt.Sprintf("invalid list index: %v", i)) } return Step{kind: ListIndexStep, key: protoreflect.ValueOfInt64(int64(i))} } // MapIndex describes index of an entry within a map. // The key type is determined by field descriptor that the map belongs to. // // Within the context of Values, // the type of the previous previous step value is always a message, // the type of the previous step value is always a map, and // the type of the current step value is determined by the field descriptor. func MapIndex(k protoreflect.MapKey) Step { if !k.IsValid() { panic("invalid map index") } return Step{kind: MapIndexStep, key: k.Value()} } // AnyExpand describes expansion of a google.protobuf.Any message into // a structured representation of the underlying message. // // Within the context of Values, // the type of the previous step value is always a google.protobuf.Any message, and // the type of the current step value is always a message. func AnyExpand(md protoreflect.MessageDescriptor) Step { if md == nil { panic("nil message descriptor") } return Step{kind: AnyExpandStep, desc: md} } // MessageDescriptor returns the message descriptor for Root or AnyExpand steps, // otherwise it returns nil. func (s Step) MessageDescriptor() protoreflect.MessageDescriptor { switch s.kind { case RootStep, AnyExpandStep: return s.desc.(protoreflect.MessageDescriptor) default: return nil } } // FieldDescriptor returns the field descriptor for FieldAccess steps, // otherwise it returns nil. func (s Step) FieldDescriptor() protoreflect.FieldDescriptor { switch s.kind { case FieldAccessStep: return s.desc.(protoreflect.FieldDescriptor) default: return nil } } // ListIndex returns the list index for ListIndex steps, // otherwise it returns 0. func (s Step) ListIndex() int { switch s.kind { case ListIndexStep: return int(s.key.Int()) default: return 0 } } // MapIndex returns the map key for MapIndex steps, // otherwise it returns an invalid map key. func (s Step) MapIndex() protoreflect.MapKey { switch s.kind { case MapIndexStep: return s.key.MapKey() default: return protoreflect.MapKey{} } } // Kind reports which kind of step this is. func (s Step) Kind() StepKind { return s.kind } func (s Step) String() string { return string(s.appendString(nil)) } func (s Step) appendString(b []byte) []byte { switch s.kind { case RootStep: b = append(b, '(') b = append(b, s.desc.FullName()...) b = append(b, ')') case FieldAccessStep: b = append(b, '.') if fd := s.desc.(protoreflect.FieldDescriptor); fd.IsExtension() { b = append(b, '(') b = append(b, strings.Trim(fd.TextName(), "[]")...) b = append(b, ')') } else { b = append(b, fd.TextName()...) } case UnknownAccessStep: b = append(b, '.') b = append(b, '?') case ListIndexStep: b = append(b, '[') b = strconv.AppendInt(b, s.key.Int(), 10) b = append(b, ']') case MapIndexStep: b = append(b, '[') switch k := s.key.Interface().(type) { case bool: b = strconv.AppendBool(b, bool(k)) // e.g., "true" or "false" case int32: b = strconv.AppendInt(b, int64(k), 10) // e.g., "-32" case int64: b = strconv.AppendInt(b, int64(k), 10) // e.g., "-64" case uint32: b = strconv.AppendUint(b, uint64(k), 10) // e.g., "32" case uint64: b = strconv.AppendUint(b, uint64(k), 10) // e.g., "64" case string: b = text.AppendString(b, k) // e.g., `"hello, world"` } b = append(b, ']') case AnyExpandStep: b = append(b, '.') b = append(b, '(') b = append(b, s.desc.FullName()...) b = append(b, ')') default: b = append(b, ""...) } return b }