planetscale 0.3.1 → 0.3.3

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (368) hide show
  1. checksums.yaml +4 -4
  2. data/.github/workflows/ci.yml +9 -1
  3. data/.github/workflows/gem-push.yml +9 -2
  4. data/.licenses/go/github.com/matoous/go-nanoid/v2.dep.yml +34 -0
  5. data/.licenses/go/github.com/planetscale/planetscale-go/planetscale.dep.yml +1 -1
  6. data/.licenses/go/github.com/planetscale/sql-proxy/proxy.dep.yml +1 -1
  7. data/.licenses/go/go.uber.org/zap/buffer.dep.yml +1 -1
  8. data/.licenses/go/go.uber.org/zap/internal/bufferpool.dep.yml +1 -1
  9. data/.licenses/go/go.uber.org/zap/internal/color.dep.yml +1 -1
  10. data/.licenses/go/go.uber.org/zap/internal/exit.dep.yml +1 -1
  11. data/.licenses/go/go.uber.org/zap/zapcore.dep.yml +1 -1
  12. data/.licenses/go/go.uber.org/zap.dep.yml +1 -1
  13. data/README.md +2 -0
  14. data/controller.go +21 -36
  15. data/go.mod +4 -3
  16. data/go.sum +32 -18
  17. data/lib/planetscale/version.rb +1 -1
  18. data/lib/planetscale.rb +2 -3
  19. data/planetscale.gemspec +1 -1
  20. data/proxy/planetscale-darwin.h +1 -1
  21. data/proxy/planetscale-darwin.so +0 -0
  22. data/proxy/planetscale-linux.h +1 -1
  23. data/proxy/planetscale-linux.so +0 -0
  24. data/proxy.go +1 -5
  25. metadata +3 -345
  26. data/vendor/github.com/armon/circbuf/.gitignore +0 -22
  27. data/vendor/github.com/armon/circbuf/LICENSE +0 -20
  28. data/vendor/github.com/armon/circbuf/README.md +0 -28
  29. data/vendor/github.com/armon/circbuf/circbuf.go +0 -92
  30. data/vendor/github.com/armon/circbuf/go.mod +0 -1
  31. data/vendor/github.com/golang/protobuf/AUTHORS +0 -3
  32. data/vendor/github.com/golang/protobuf/CONTRIBUTORS +0 -3
  33. data/vendor/github.com/golang/protobuf/LICENSE +0 -28
  34. data/vendor/github.com/golang/protobuf/proto/buffer.go +0 -324
  35. data/vendor/github.com/golang/protobuf/proto/defaults.go +0 -63
  36. data/vendor/github.com/golang/protobuf/proto/deprecated.go +0 -113
  37. data/vendor/github.com/golang/protobuf/proto/discard.go +0 -58
  38. data/vendor/github.com/golang/protobuf/proto/extensions.go +0 -356
  39. data/vendor/github.com/golang/protobuf/proto/properties.go +0 -306
  40. data/vendor/github.com/golang/protobuf/proto/proto.go +0 -167
  41. data/vendor/github.com/golang/protobuf/proto/registry.go +0 -317
  42. data/vendor/github.com/golang/protobuf/proto/text_decode.go +0 -801
  43. data/vendor/github.com/golang/protobuf/proto/text_encode.go +0 -560
  44. data/vendor/github.com/golang/protobuf/proto/wire.go +0 -78
  45. data/vendor/github.com/golang/protobuf/proto/wrappers.go +0 -34
  46. data/vendor/github.com/gorilla/mux/AUTHORS +0 -8
  47. data/vendor/github.com/gorilla/mux/LICENSE +0 -27
  48. data/vendor/github.com/gorilla/mux/README.md +0 -805
  49. data/vendor/github.com/gorilla/mux/doc.go +0 -306
  50. data/vendor/github.com/gorilla/mux/go.mod +0 -3
  51. data/vendor/github.com/gorilla/mux/middleware.go +0 -74
  52. data/vendor/github.com/gorilla/mux/mux.go +0 -606
  53. data/vendor/github.com/gorilla/mux/regexp.go +0 -388
  54. data/vendor/github.com/gorilla/mux/route.go +0 -736
  55. data/vendor/github.com/gorilla/mux/test_helpers.go +0 -19
  56. data/vendor/github.com/hashicorp/go-cleanhttp/LICENSE +0 -363
  57. data/vendor/github.com/hashicorp/go-cleanhttp/README.md +0 -30
  58. data/vendor/github.com/hashicorp/go-cleanhttp/cleanhttp.go +0 -58
  59. data/vendor/github.com/hashicorp/go-cleanhttp/doc.go +0 -20
  60. data/vendor/github.com/hashicorp/go-cleanhttp/go.mod +0 -3
  61. data/vendor/github.com/hashicorp/go-cleanhttp/handlers.go +0 -48
  62. data/vendor/github.com/mitchellh/go-homedir/LICENSE +0 -21
  63. data/vendor/github.com/mitchellh/go-homedir/README.md +0 -14
  64. data/vendor/github.com/mitchellh/go-homedir/go.mod +0 -1
  65. data/vendor/github.com/mitchellh/go-homedir/homedir.go +0 -167
  66. data/vendor/github.com/pkg/errors/.gitignore +0 -24
  67. data/vendor/github.com/pkg/errors/.travis.yml +0 -10
  68. data/vendor/github.com/pkg/errors/LICENSE +0 -23
  69. data/vendor/github.com/pkg/errors/Makefile +0 -44
  70. data/vendor/github.com/pkg/errors/README.md +0 -59
  71. data/vendor/github.com/pkg/errors/appveyor.yml +0 -32
  72. data/vendor/github.com/pkg/errors/errors.go +0 -288
  73. data/vendor/github.com/pkg/errors/go113.go +0 -38
  74. data/vendor/github.com/pkg/errors/stack.go +0 -177
  75. data/vendor/github.com/planetscale/planetscale-go/LICENSE +0 -202
  76. data/vendor/github.com/planetscale/planetscale-go/planetscale/audit_logs.go +0 -136
  77. data/vendor/github.com/planetscale/planetscale-go/planetscale/backups.go +0 -139
  78. data/vendor/github.com/planetscale/planetscale-go/planetscale/branches.go +0 -252
  79. data/vendor/github.com/planetscale/planetscale-go/planetscale/certs.go +0 -166
  80. data/vendor/github.com/planetscale/planetscale-go/planetscale/client.go +0 -312
  81. data/vendor/github.com/planetscale/planetscale-go/planetscale/databases.go +0 -133
  82. data/vendor/github.com/planetscale/planetscale-go/planetscale/deploy_requests.go +0 -368
  83. data/vendor/github.com/planetscale/planetscale-go/planetscale/organizations.go +0 -103
  84. data/vendor/github.com/planetscale/planetscale-go/planetscale/regions.go +0 -52
  85. data/vendor/github.com/planetscale/planetscale-go/planetscale/service_tokens.go +0 -163
  86. data/vendor/github.com/planetscale/sql-proxy/LICENSE +0 -202
  87. data/vendor/github.com/planetscale/sql-proxy/proxy/client.go +0 -476
  88. data/vendor/github.com/planetscale/sql-proxy/proxy/tls_cache.go +0 -73
  89. data/vendor/go.uber.org/atomic/.codecov.yml +0 -19
  90. data/vendor/go.uber.org/atomic/.gitignore +0 -12
  91. data/vendor/go.uber.org/atomic/.travis.yml +0 -27
  92. data/vendor/go.uber.org/atomic/CHANGELOG.md +0 -76
  93. data/vendor/go.uber.org/atomic/LICENSE.txt +0 -19
  94. data/vendor/go.uber.org/atomic/Makefile +0 -78
  95. data/vendor/go.uber.org/atomic/README.md +0 -63
  96. data/vendor/go.uber.org/atomic/bool.go +0 -81
  97. data/vendor/go.uber.org/atomic/bool_ext.go +0 -53
  98. data/vendor/go.uber.org/atomic/doc.go +0 -23
  99. data/vendor/go.uber.org/atomic/duration.go +0 -82
  100. data/vendor/go.uber.org/atomic/duration_ext.go +0 -40
  101. data/vendor/go.uber.org/atomic/error.go +0 -51
  102. data/vendor/go.uber.org/atomic/error_ext.go +0 -39
  103. data/vendor/go.uber.org/atomic/float64.go +0 -76
  104. data/vendor/go.uber.org/atomic/float64_ext.go +0 -47
  105. data/vendor/go.uber.org/atomic/gen.go +0 -26
  106. data/vendor/go.uber.org/atomic/go.mod +0 -8
  107. data/vendor/go.uber.org/atomic/go.sum +0 -9
  108. data/vendor/go.uber.org/atomic/int32.go +0 -102
  109. data/vendor/go.uber.org/atomic/int64.go +0 -102
  110. data/vendor/go.uber.org/atomic/nocmp.go +0 -35
  111. data/vendor/go.uber.org/atomic/string.go +0 -54
  112. data/vendor/go.uber.org/atomic/string_ext.go +0 -43
  113. data/vendor/go.uber.org/atomic/uint32.go +0 -102
  114. data/vendor/go.uber.org/atomic/uint64.go +0 -102
  115. data/vendor/go.uber.org/atomic/value.go +0 -31
  116. data/vendor/go.uber.org/multierr/.codecov.yml +0 -15
  117. data/vendor/go.uber.org/multierr/.gitignore +0 -4
  118. data/vendor/go.uber.org/multierr/.travis.yml +0 -23
  119. data/vendor/go.uber.org/multierr/CHANGELOG.md +0 -60
  120. data/vendor/go.uber.org/multierr/LICENSE.txt +0 -19
  121. data/vendor/go.uber.org/multierr/Makefile +0 -42
  122. data/vendor/go.uber.org/multierr/README.md +0 -23
  123. data/vendor/go.uber.org/multierr/error.go +0 -449
  124. data/vendor/go.uber.org/multierr/glide.yaml +0 -8
  125. data/vendor/go.uber.org/multierr/go.mod +0 -8
  126. data/vendor/go.uber.org/multierr/go.sum +0 -11
  127. data/vendor/go.uber.org/multierr/go113.go +0 -52
  128. data/vendor/go.uber.org/zap/.codecov.yml +0 -17
  129. data/vendor/go.uber.org/zap/.gitignore +0 -32
  130. data/vendor/go.uber.org/zap/.readme.tmpl +0 -109
  131. data/vendor/go.uber.org/zap/CHANGELOG.md +0 -492
  132. data/vendor/go.uber.org/zap/CODE_OF_CONDUCT.md +0 -75
  133. data/vendor/go.uber.org/zap/CONTRIBUTING.md +0 -75
  134. data/vendor/go.uber.org/zap/FAQ.md +0 -164
  135. data/vendor/go.uber.org/zap/LICENSE.txt +0 -19
  136. data/vendor/go.uber.org/zap/Makefile +0 -73
  137. data/vendor/go.uber.org/zap/README.md +0 -134
  138. data/vendor/go.uber.org/zap/array.go +0 -320
  139. data/vendor/go.uber.org/zap/buffer/buffer.go +0 -141
  140. data/vendor/go.uber.org/zap/buffer/pool.go +0 -49
  141. data/vendor/go.uber.org/zap/checklicense.sh +0 -17
  142. data/vendor/go.uber.org/zap/config.go +0 -264
  143. data/vendor/go.uber.org/zap/doc.go +0 -113
  144. data/vendor/go.uber.org/zap/encoder.go +0 -79
  145. data/vendor/go.uber.org/zap/error.go +0 -80
  146. data/vendor/go.uber.org/zap/field.go +0 -549
  147. data/vendor/go.uber.org/zap/flag.go +0 -39
  148. data/vendor/go.uber.org/zap/glide.yaml +0 -34
  149. data/vendor/go.uber.org/zap/global.go +0 -168
  150. data/vendor/go.uber.org/zap/global_go112.go +0 -26
  151. data/vendor/go.uber.org/zap/global_prego112.go +0 -26
  152. data/vendor/go.uber.org/zap/go.mod +0 -14
  153. data/vendor/go.uber.org/zap/go.sum +0 -54
  154. data/vendor/go.uber.org/zap/http_handler.go +0 -132
  155. data/vendor/go.uber.org/zap/internal/bufferpool/bufferpool.go +0 -31
  156. data/vendor/go.uber.org/zap/internal/color/color.go +0 -44
  157. data/vendor/go.uber.org/zap/internal/exit/exit.go +0 -64
  158. data/vendor/go.uber.org/zap/level.go +0 -132
  159. data/vendor/go.uber.org/zap/logger.go +0 -348
  160. data/vendor/go.uber.org/zap/options.go +0 -148
  161. data/vendor/go.uber.org/zap/sink.go +0 -161
  162. data/vendor/go.uber.org/zap/stacktrace.go +0 -85
  163. data/vendor/go.uber.org/zap/sugar.go +0 -315
  164. data/vendor/go.uber.org/zap/time.go +0 -27
  165. data/vendor/go.uber.org/zap/writer.go +0 -99
  166. data/vendor/go.uber.org/zap/zapcore/buffered_write_syncer.go +0 -188
  167. data/vendor/go.uber.org/zap/zapcore/clock.go +0 -50
  168. data/vendor/go.uber.org/zap/zapcore/console_encoder.go +0 -161
  169. data/vendor/go.uber.org/zap/zapcore/core.go +0 -113
  170. data/vendor/go.uber.org/zap/zapcore/doc.go +0 -24
  171. data/vendor/go.uber.org/zap/zapcore/encoder.go +0 -443
  172. data/vendor/go.uber.org/zap/zapcore/entry.go +0 -264
  173. data/vendor/go.uber.org/zap/zapcore/error.go +0 -132
  174. data/vendor/go.uber.org/zap/zapcore/field.go +0 -233
  175. data/vendor/go.uber.org/zap/zapcore/hook.go +0 -68
  176. data/vendor/go.uber.org/zap/zapcore/increase_level.go +0 -66
  177. data/vendor/go.uber.org/zap/zapcore/json_encoder.go +0 -534
  178. data/vendor/go.uber.org/zap/zapcore/level.go +0 -175
  179. data/vendor/go.uber.org/zap/zapcore/level_strings.go +0 -46
  180. data/vendor/go.uber.org/zap/zapcore/marshaler.go +0 -61
  181. data/vendor/go.uber.org/zap/zapcore/memory_encoder.go +0 -179
  182. data/vendor/go.uber.org/zap/zapcore/sampler.go +0 -208
  183. data/vendor/go.uber.org/zap/zapcore/tee.go +0 -81
  184. data/vendor/go.uber.org/zap/zapcore/write_syncer.go +0 -122
  185. data/vendor/golang.org/x/net/AUTHORS +0 -3
  186. data/vendor/golang.org/x/net/CONTRIBUTORS +0 -3
  187. data/vendor/golang.org/x/net/LICENSE +0 -27
  188. data/vendor/golang.org/x/net/PATENTS +0 -22
  189. data/vendor/golang.org/x/net/context/context.go +0 -56
  190. data/vendor/golang.org/x/net/context/ctxhttp/ctxhttp.go +0 -71
  191. data/vendor/golang.org/x/net/context/go17.go +0 -73
  192. data/vendor/golang.org/x/net/context/go19.go +0 -21
  193. data/vendor/golang.org/x/net/context/pre_go17.go +0 -301
  194. data/vendor/golang.org/x/net/context/pre_go19.go +0 -110
  195. data/vendor/golang.org/x/oauth2/.travis.yml +0 -13
  196. data/vendor/golang.org/x/oauth2/AUTHORS +0 -3
  197. data/vendor/golang.org/x/oauth2/CONTRIBUTING.md +0 -26
  198. data/vendor/golang.org/x/oauth2/CONTRIBUTORS +0 -3
  199. data/vendor/golang.org/x/oauth2/LICENSE +0 -27
  200. data/vendor/golang.org/x/oauth2/README.md +0 -36
  201. data/vendor/golang.org/x/oauth2/go.mod +0 -9
  202. data/vendor/golang.org/x/oauth2/go.sum +0 -361
  203. data/vendor/golang.org/x/oauth2/internal/client_appengine.go +0 -14
  204. data/vendor/golang.org/x/oauth2/internal/doc.go +0 -6
  205. data/vendor/golang.org/x/oauth2/internal/oauth2.go +0 -37
  206. data/vendor/golang.org/x/oauth2/internal/token.go +0 -294
  207. data/vendor/golang.org/x/oauth2/internal/transport.go +0 -33
  208. data/vendor/golang.org/x/oauth2/oauth2.go +0 -381
  209. data/vendor/golang.org/x/oauth2/token.go +0 -178
  210. data/vendor/golang.org/x/oauth2/transport.go +0 -89
  211. data/vendor/google.golang.org/appengine/LICENSE +0 -202
  212. data/vendor/google.golang.org/appengine/internal/api.go +0 -678
  213. data/vendor/google.golang.org/appengine/internal/api_classic.go +0 -169
  214. data/vendor/google.golang.org/appengine/internal/api_common.go +0 -123
  215. data/vendor/google.golang.org/appengine/internal/app_id.go +0 -28
  216. data/vendor/google.golang.org/appengine/internal/base/api_base.pb.go +0 -308
  217. data/vendor/google.golang.org/appengine/internal/base/api_base.proto +0 -33
  218. data/vendor/google.golang.org/appengine/internal/datastore/datastore_v3.pb.go +0 -4367
  219. data/vendor/google.golang.org/appengine/internal/datastore/datastore_v3.proto +0 -551
  220. data/vendor/google.golang.org/appengine/internal/identity.go +0 -55
  221. data/vendor/google.golang.org/appengine/internal/identity_classic.go +0 -61
  222. data/vendor/google.golang.org/appengine/internal/identity_flex.go +0 -11
  223. data/vendor/google.golang.org/appengine/internal/identity_vm.go +0 -134
  224. data/vendor/google.golang.org/appengine/internal/internal.go +0 -110
  225. data/vendor/google.golang.org/appengine/internal/log/log_service.pb.go +0 -1313
  226. data/vendor/google.golang.org/appengine/internal/log/log_service.proto +0 -150
  227. data/vendor/google.golang.org/appengine/internal/main.go +0 -16
  228. data/vendor/google.golang.org/appengine/internal/main_common.go +0 -7
  229. data/vendor/google.golang.org/appengine/internal/main_vm.go +0 -69
  230. data/vendor/google.golang.org/appengine/internal/metadata.go +0 -60
  231. data/vendor/google.golang.org/appengine/internal/net.go +0 -56
  232. data/vendor/google.golang.org/appengine/internal/regen.sh +0 -40
  233. data/vendor/google.golang.org/appengine/internal/remote_api/remote_api.pb.go +0 -361
  234. data/vendor/google.golang.org/appengine/internal/remote_api/remote_api.proto +0 -44
  235. data/vendor/google.golang.org/appengine/internal/transaction.go +0 -115
  236. data/vendor/google.golang.org/appengine/internal/urlfetch/urlfetch_service.pb.go +0 -527
  237. data/vendor/google.golang.org/appengine/internal/urlfetch/urlfetch_service.proto +0 -64
  238. data/vendor/google.golang.org/appengine/urlfetch/urlfetch.go +0 -210
  239. data/vendor/google.golang.org/protobuf/AUTHORS +0 -3
  240. data/vendor/google.golang.org/protobuf/CONTRIBUTORS +0 -3
  241. data/vendor/google.golang.org/protobuf/LICENSE +0 -27
  242. data/vendor/google.golang.org/protobuf/PATENTS +0 -22
  243. data/vendor/google.golang.org/protobuf/encoding/prototext/decode.go +0 -773
  244. data/vendor/google.golang.org/protobuf/encoding/prototext/doc.go +0 -7
  245. data/vendor/google.golang.org/protobuf/encoding/prototext/encode.go +0 -371
  246. data/vendor/google.golang.org/protobuf/encoding/protowire/wire.go +0 -538
  247. data/vendor/google.golang.org/protobuf/internal/descfmt/stringer.go +0 -318
  248. data/vendor/google.golang.org/protobuf/internal/descopts/options.go +0 -29
  249. data/vendor/google.golang.org/protobuf/internal/detrand/rand.go +0 -69
  250. data/vendor/google.golang.org/protobuf/internal/encoding/defval/default.go +0 -213
  251. data/vendor/google.golang.org/protobuf/internal/encoding/messageset/messageset.go +0 -241
  252. data/vendor/google.golang.org/protobuf/internal/encoding/tag/tag.go +0 -207
  253. data/vendor/google.golang.org/protobuf/internal/encoding/text/decode.go +0 -665
  254. data/vendor/google.golang.org/protobuf/internal/encoding/text/decode_number.go +0 -190
  255. data/vendor/google.golang.org/protobuf/internal/encoding/text/decode_string.go +0 -161
  256. data/vendor/google.golang.org/protobuf/internal/encoding/text/decode_token.go +0 -373
  257. data/vendor/google.golang.org/protobuf/internal/encoding/text/doc.go +0 -29
  258. data/vendor/google.golang.org/protobuf/internal/encoding/text/encode.go +0 -265
  259. data/vendor/google.golang.org/protobuf/internal/errors/errors.go +0 -89
  260. data/vendor/google.golang.org/protobuf/internal/errors/is_go112.go +0 -39
  261. data/vendor/google.golang.org/protobuf/internal/errors/is_go113.go +0 -12
  262. data/vendor/google.golang.org/protobuf/internal/filedesc/build.go +0 -158
  263. data/vendor/google.golang.org/protobuf/internal/filedesc/desc.go +0 -631
  264. data/vendor/google.golang.org/protobuf/internal/filedesc/desc_init.go +0 -471
  265. data/vendor/google.golang.org/protobuf/internal/filedesc/desc_lazy.go +0 -704
  266. data/vendor/google.golang.org/protobuf/internal/filedesc/desc_list.go +0 -450
  267. data/vendor/google.golang.org/protobuf/internal/filedesc/desc_list_gen.go +0 -356
  268. data/vendor/google.golang.org/protobuf/internal/filedesc/placeholder.go +0 -107
  269. data/vendor/google.golang.org/protobuf/internal/filetype/build.go +0 -297
  270. data/vendor/google.golang.org/protobuf/internal/flags/flags.go +0 -24
  271. data/vendor/google.golang.org/protobuf/internal/flags/proto_legacy_disable.go +0 -9
  272. data/vendor/google.golang.org/protobuf/internal/flags/proto_legacy_enable.go +0 -9
  273. data/vendor/google.golang.org/protobuf/internal/genid/any_gen.go +0 -34
  274. data/vendor/google.golang.org/protobuf/internal/genid/api_gen.go +0 -106
  275. data/vendor/google.golang.org/protobuf/internal/genid/descriptor_gen.go +0 -829
  276. data/vendor/google.golang.org/protobuf/internal/genid/doc.go +0 -11
  277. data/vendor/google.golang.org/protobuf/internal/genid/duration_gen.go +0 -34
  278. data/vendor/google.golang.org/protobuf/internal/genid/empty_gen.go +0 -19
  279. data/vendor/google.golang.org/protobuf/internal/genid/field_mask_gen.go +0 -31
  280. data/vendor/google.golang.org/protobuf/internal/genid/goname.go +0 -25
  281. data/vendor/google.golang.org/protobuf/internal/genid/map_entry.go +0 -16
  282. data/vendor/google.golang.org/protobuf/internal/genid/source_context_gen.go +0 -31
  283. data/vendor/google.golang.org/protobuf/internal/genid/struct_gen.go +0 -116
  284. data/vendor/google.golang.org/protobuf/internal/genid/timestamp_gen.go +0 -34
  285. data/vendor/google.golang.org/protobuf/internal/genid/type_gen.go +0 -184
  286. data/vendor/google.golang.org/protobuf/internal/genid/wrappers.go +0 -13
  287. data/vendor/google.golang.org/protobuf/internal/genid/wrappers_gen.go +0 -175
  288. data/vendor/google.golang.org/protobuf/internal/impl/api_export.go +0 -177
  289. data/vendor/google.golang.org/protobuf/internal/impl/checkinit.go +0 -141
  290. data/vendor/google.golang.org/protobuf/internal/impl/codec_extension.go +0 -223
  291. data/vendor/google.golang.org/protobuf/internal/impl/codec_field.go +0 -830
  292. data/vendor/google.golang.org/protobuf/internal/impl/codec_gen.go +0 -5637
  293. data/vendor/google.golang.org/protobuf/internal/impl/codec_map.go +0 -388
  294. data/vendor/google.golang.org/protobuf/internal/impl/codec_map_go111.go +0 -37
  295. data/vendor/google.golang.org/protobuf/internal/impl/codec_map_go112.go +0 -11
  296. data/vendor/google.golang.org/protobuf/internal/impl/codec_message.go +0 -217
  297. data/vendor/google.golang.org/protobuf/internal/impl/codec_messageset.go +0 -123
  298. data/vendor/google.golang.org/protobuf/internal/impl/codec_reflect.go +0 -209
  299. data/vendor/google.golang.org/protobuf/internal/impl/codec_tables.go +0 -557
  300. data/vendor/google.golang.org/protobuf/internal/impl/codec_unsafe.go +0 -17
  301. data/vendor/google.golang.org/protobuf/internal/impl/convert.go +0 -496
  302. data/vendor/google.golang.org/protobuf/internal/impl/convert_list.go +0 -141
  303. data/vendor/google.golang.org/protobuf/internal/impl/convert_map.go +0 -121
  304. data/vendor/google.golang.org/protobuf/internal/impl/decode.go +0 -276
  305. data/vendor/google.golang.org/protobuf/internal/impl/encode.go +0 -201
  306. data/vendor/google.golang.org/protobuf/internal/impl/enum.go +0 -21
  307. data/vendor/google.golang.org/protobuf/internal/impl/extension.go +0 -156
  308. data/vendor/google.golang.org/protobuf/internal/impl/legacy_enum.go +0 -219
  309. data/vendor/google.golang.org/protobuf/internal/impl/legacy_export.go +0 -92
  310. data/vendor/google.golang.org/protobuf/internal/impl/legacy_extension.go +0 -176
  311. data/vendor/google.golang.org/protobuf/internal/impl/legacy_file.go +0 -81
  312. data/vendor/google.golang.org/protobuf/internal/impl/legacy_message.go +0 -558
  313. data/vendor/google.golang.org/protobuf/internal/impl/merge.go +0 -176
  314. data/vendor/google.golang.org/protobuf/internal/impl/merge_gen.go +0 -209
  315. data/vendor/google.golang.org/protobuf/internal/impl/message.go +0 -276
  316. data/vendor/google.golang.org/protobuf/internal/impl/message_reflect.go +0 -465
  317. data/vendor/google.golang.org/protobuf/internal/impl/message_reflect_field.go +0 -543
  318. data/vendor/google.golang.org/protobuf/internal/impl/message_reflect_gen.go +0 -249
  319. data/vendor/google.golang.org/protobuf/internal/impl/pointer_reflect.go +0 -178
  320. data/vendor/google.golang.org/protobuf/internal/impl/pointer_unsafe.go +0 -174
  321. data/vendor/google.golang.org/protobuf/internal/impl/validate.go +0 -576
  322. data/vendor/google.golang.org/protobuf/internal/impl/weak.go +0 -74
  323. data/vendor/google.golang.org/protobuf/internal/order/order.go +0 -89
  324. data/vendor/google.golang.org/protobuf/internal/order/range.go +0 -115
  325. data/vendor/google.golang.org/protobuf/internal/pragma/pragma.go +0 -29
  326. data/vendor/google.golang.org/protobuf/internal/set/ints.go +0 -58
  327. data/vendor/google.golang.org/protobuf/internal/strs/strings.go +0 -196
  328. data/vendor/google.golang.org/protobuf/internal/strs/strings_pure.go +0 -27
  329. data/vendor/google.golang.org/protobuf/internal/strs/strings_unsafe.go +0 -94
  330. data/vendor/google.golang.org/protobuf/internal/version/version.go +0 -79
  331. data/vendor/google.golang.org/protobuf/proto/checkinit.go +0 -71
  332. data/vendor/google.golang.org/protobuf/proto/decode.go +0 -278
  333. data/vendor/google.golang.org/protobuf/proto/decode_gen.go +0 -603
  334. data/vendor/google.golang.org/protobuf/proto/doc.go +0 -94
  335. data/vendor/google.golang.org/protobuf/proto/encode.go +0 -319
  336. data/vendor/google.golang.org/protobuf/proto/encode_gen.go +0 -97
  337. data/vendor/google.golang.org/protobuf/proto/equal.go +0 -167
  338. data/vendor/google.golang.org/protobuf/proto/extension.go +0 -92
  339. data/vendor/google.golang.org/protobuf/proto/merge.go +0 -139
  340. data/vendor/google.golang.org/protobuf/proto/messageset.go +0 -93
  341. data/vendor/google.golang.org/protobuf/proto/proto.go +0 -43
  342. data/vendor/google.golang.org/protobuf/proto/proto_methods.go +0 -19
  343. data/vendor/google.golang.org/protobuf/proto/proto_reflect.go +0 -19
  344. data/vendor/google.golang.org/protobuf/proto/reset.go +0 -43
  345. data/vendor/google.golang.org/protobuf/proto/size.go +0 -97
  346. data/vendor/google.golang.org/protobuf/proto/size_gen.go +0 -55
  347. data/vendor/google.golang.org/protobuf/proto/wrappers.go +0 -29
  348. data/vendor/google.golang.org/protobuf/reflect/protodesc/desc.go +0 -276
  349. data/vendor/google.golang.org/protobuf/reflect/protodesc/desc_init.go +0 -248
  350. data/vendor/google.golang.org/protobuf/reflect/protodesc/desc_resolve.go +0 -286
  351. data/vendor/google.golang.org/protobuf/reflect/protodesc/desc_validate.go +0 -374
  352. data/vendor/google.golang.org/protobuf/reflect/protodesc/proto.go +0 -252
  353. data/vendor/google.golang.org/protobuf/reflect/protoreflect/methods.go +0 -77
  354. data/vendor/google.golang.org/protobuf/reflect/protoreflect/proto.go +0 -504
  355. data/vendor/google.golang.org/protobuf/reflect/protoreflect/source.go +0 -128
  356. data/vendor/google.golang.org/protobuf/reflect/protoreflect/source_gen.go +0 -461
  357. data/vendor/google.golang.org/protobuf/reflect/protoreflect/type.go +0 -665
  358. data/vendor/google.golang.org/protobuf/reflect/protoreflect/value.go +0 -285
  359. data/vendor/google.golang.org/protobuf/reflect/protoreflect/value_pure.go +0 -59
  360. data/vendor/google.golang.org/protobuf/reflect/protoreflect/value_union.go +0 -411
  361. data/vendor/google.golang.org/protobuf/reflect/protoreflect/value_unsafe.go +0 -98
  362. data/vendor/google.golang.org/protobuf/reflect/protoregistry/registry.go +0 -869
  363. data/vendor/google.golang.org/protobuf/runtime/protoiface/legacy.go +0 -15
  364. data/vendor/google.golang.org/protobuf/runtime/protoiface/methods.go +0 -167
  365. data/vendor/google.golang.org/protobuf/runtime/protoimpl/impl.go +0 -44
  366. data/vendor/google.golang.org/protobuf/runtime/protoimpl/version.go +0 -56
  367. data/vendor/google.golang.org/protobuf/types/descriptorpb/descriptor.pb.go +0 -4039
  368. data/vendor/modules.txt +0 -79
@@ -1,830 +0,0 @@
1
- // Copyright 2019 The Go Authors. All rights reserved.
2
- // Use of this source code is governed by a BSD-style
3
- // license that can be found in the LICENSE file.
4
-
5
- package impl
6
-
7
- import (
8
- "fmt"
9
- "reflect"
10
- "sync"
11
-
12
- "google.golang.org/protobuf/encoding/protowire"
13
- "google.golang.org/protobuf/internal/errors"
14
- "google.golang.org/protobuf/proto"
15
- pref "google.golang.org/protobuf/reflect/protoreflect"
16
- preg "google.golang.org/protobuf/reflect/protoregistry"
17
- piface "google.golang.org/protobuf/runtime/protoiface"
18
- )
19
-
20
- type errInvalidUTF8 struct{}
21
-
22
- func (errInvalidUTF8) Error() string { return "string field contains invalid UTF-8" }
23
- func (errInvalidUTF8) InvalidUTF8() bool { return true }
24
- func (errInvalidUTF8) Unwrap() error { return errors.Error }
25
-
26
- // initOneofFieldCoders initializes the fast-path functions for the fields in a oneof.
27
- //
28
- // For size, marshal, and isInit operations, functions are set only on the first field
29
- // in the oneof. The functions are called when the oneof is non-nil, and will dispatch
30
- // to the appropriate field-specific function as necessary.
31
- //
32
- // The unmarshal function is set on each field individually as usual.
33
- func (mi *MessageInfo) initOneofFieldCoders(od pref.OneofDescriptor, si structInfo) {
34
- fs := si.oneofsByName[od.Name()]
35
- ft := fs.Type
36
- oneofFields := make(map[reflect.Type]*coderFieldInfo)
37
- needIsInit := false
38
- fields := od.Fields()
39
- for i, lim := 0, fields.Len(); i < lim; i++ {
40
- fd := od.Fields().Get(i)
41
- num := fd.Number()
42
- // Make a copy of the original coderFieldInfo for use in unmarshaling.
43
- //
44
- // oneofFields[oneofType].funcs.marshal is the field-specific marshal function.
45
- //
46
- // mi.coderFields[num].marshal is set on only the first field in the oneof,
47
- // and dispatches to the field-specific marshaler in oneofFields.
48
- cf := *mi.coderFields[num]
49
- ot := si.oneofWrappersByNumber[num]
50
- cf.ft = ot.Field(0).Type
51
- cf.mi, cf.funcs = fieldCoder(fd, cf.ft)
52
- oneofFields[ot] = &cf
53
- if cf.funcs.isInit != nil {
54
- needIsInit = true
55
- }
56
- mi.coderFields[num].funcs.unmarshal = func(b []byte, p pointer, wtyp protowire.Type, f *coderFieldInfo, opts unmarshalOptions) (unmarshalOutput, error) {
57
- var vw reflect.Value // pointer to wrapper type
58
- vi := p.AsValueOf(ft).Elem() // oneof field value of interface kind
59
- if !vi.IsNil() && !vi.Elem().IsNil() && vi.Elem().Elem().Type() == ot {
60
- vw = vi.Elem()
61
- } else {
62
- vw = reflect.New(ot)
63
- }
64
- out, err := cf.funcs.unmarshal(b, pointerOfValue(vw).Apply(zeroOffset), wtyp, &cf, opts)
65
- if err != nil {
66
- return out, err
67
- }
68
- vi.Set(vw)
69
- return out, nil
70
- }
71
- }
72
- getInfo := func(p pointer) (pointer, *coderFieldInfo) {
73
- v := p.AsValueOf(ft).Elem()
74
- if v.IsNil() {
75
- return pointer{}, nil
76
- }
77
- v = v.Elem() // interface -> *struct
78
- if v.IsNil() {
79
- return pointer{}, nil
80
- }
81
- return pointerOfValue(v).Apply(zeroOffset), oneofFields[v.Elem().Type()]
82
- }
83
- first := mi.coderFields[od.Fields().Get(0).Number()]
84
- first.funcs.size = func(p pointer, _ *coderFieldInfo, opts marshalOptions) int {
85
- p, info := getInfo(p)
86
- if info == nil || info.funcs.size == nil {
87
- return 0
88
- }
89
- return info.funcs.size(p, info, opts)
90
- }
91
- first.funcs.marshal = func(b []byte, p pointer, _ *coderFieldInfo, opts marshalOptions) ([]byte, error) {
92
- p, info := getInfo(p)
93
- if info == nil || info.funcs.marshal == nil {
94
- return b, nil
95
- }
96
- return info.funcs.marshal(b, p, info, opts)
97
- }
98
- first.funcs.merge = func(dst, src pointer, _ *coderFieldInfo, opts mergeOptions) {
99
- srcp, srcinfo := getInfo(src)
100
- if srcinfo == nil || srcinfo.funcs.merge == nil {
101
- return
102
- }
103
- dstp, dstinfo := getInfo(dst)
104
- if dstinfo != srcinfo {
105
- dst.AsValueOf(ft).Elem().Set(reflect.New(src.AsValueOf(ft).Elem().Elem().Elem().Type()))
106
- dstp = pointerOfValue(dst.AsValueOf(ft).Elem().Elem()).Apply(zeroOffset)
107
- }
108
- srcinfo.funcs.merge(dstp, srcp, srcinfo, opts)
109
- }
110
- if needIsInit {
111
- first.funcs.isInit = func(p pointer, _ *coderFieldInfo) error {
112
- p, info := getInfo(p)
113
- if info == nil || info.funcs.isInit == nil {
114
- return nil
115
- }
116
- return info.funcs.isInit(p, info)
117
- }
118
- }
119
- }
120
-
121
- func makeWeakMessageFieldCoder(fd pref.FieldDescriptor) pointerCoderFuncs {
122
- var once sync.Once
123
- var messageType pref.MessageType
124
- lazyInit := func() {
125
- once.Do(func() {
126
- messageName := fd.Message().FullName()
127
- messageType, _ = preg.GlobalTypes.FindMessageByName(messageName)
128
- })
129
- }
130
-
131
- return pointerCoderFuncs{
132
- size: func(p pointer, f *coderFieldInfo, opts marshalOptions) int {
133
- m, ok := p.WeakFields().get(f.num)
134
- if !ok {
135
- return 0
136
- }
137
- lazyInit()
138
- if messageType == nil {
139
- panic(fmt.Sprintf("weak message %v is not linked in", fd.Message().FullName()))
140
- }
141
- return sizeMessage(m, f.tagsize, opts)
142
- },
143
- marshal: func(b []byte, p pointer, f *coderFieldInfo, opts marshalOptions) ([]byte, error) {
144
- m, ok := p.WeakFields().get(f.num)
145
- if !ok {
146
- return b, nil
147
- }
148
- lazyInit()
149
- if messageType == nil {
150
- panic(fmt.Sprintf("weak message %v is not linked in", fd.Message().FullName()))
151
- }
152
- return appendMessage(b, m, f.wiretag, opts)
153
- },
154
- unmarshal: func(b []byte, p pointer, wtyp protowire.Type, f *coderFieldInfo, opts unmarshalOptions) (unmarshalOutput, error) {
155
- fs := p.WeakFields()
156
- m, ok := fs.get(f.num)
157
- if !ok {
158
- lazyInit()
159
- if messageType == nil {
160
- return unmarshalOutput{}, errUnknown
161
- }
162
- m = messageType.New().Interface()
163
- fs.set(f.num, m)
164
- }
165
- return consumeMessage(b, m, wtyp, opts)
166
- },
167
- isInit: func(p pointer, f *coderFieldInfo) error {
168
- m, ok := p.WeakFields().get(f.num)
169
- if !ok {
170
- return nil
171
- }
172
- return proto.CheckInitialized(m)
173
- },
174
- merge: func(dst, src pointer, f *coderFieldInfo, opts mergeOptions) {
175
- sm, ok := src.WeakFields().get(f.num)
176
- if !ok {
177
- return
178
- }
179
- dm, ok := dst.WeakFields().get(f.num)
180
- if !ok {
181
- lazyInit()
182
- if messageType == nil {
183
- panic(fmt.Sprintf("weak message %v is not linked in", fd.Message().FullName()))
184
- }
185
- dm = messageType.New().Interface()
186
- dst.WeakFields().set(f.num, dm)
187
- }
188
- opts.Merge(dm, sm)
189
- },
190
- }
191
- }
192
-
193
- func makeMessageFieldCoder(fd pref.FieldDescriptor, ft reflect.Type) pointerCoderFuncs {
194
- if mi := getMessageInfo(ft); mi != nil {
195
- funcs := pointerCoderFuncs{
196
- size: sizeMessageInfo,
197
- marshal: appendMessageInfo,
198
- unmarshal: consumeMessageInfo,
199
- merge: mergeMessage,
200
- }
201
- if needsInitCheck(mi.Desc) {
202
- funcs.isInit = isInitMessageInfo
203
- }
204
- return funcs
205
- } else {
206
- return pointerCoderFuncs{
207
- size: func(p pointer, f *coderFieldInfo, opts marshalOptions) int {
208
- m := asMessage(p.AsValueOf(ft).Elem())
209
- return sizeMessage(m, f.tagsize, opts)
210
- },
211
- marshal: func(b []byte, p pointer, f *coderFieldInfo, opts marshalOptions) ([]byte, error) {
212
- m := asMessage(p.AsValueOf(ft).Elem())
213
- return appendMessage(b, m, f.wiretag, opts)
214
- },
215
- unmarshal: func(b []byte, p pointer, wtyp protowire.Type, f *coderFieldInfo, opts unmarshalOptions) (unmarshalOutput, error) {
216
- mp := p.AsValueOf(ft).Elem()
217
- if mp.IsNil() {
218
- mp.Set(reflect.New(ft.Elem()))
219
- }
220
- return consumeMessage(b, asMessage(mp), wtyp, opts)
221
- },
222
- isInit: func(p pointer, f *coderFieldInfo) error {
223
- m := asMessage(p.AsValueOf(ft).Elem())
224
- return proto.CheckInitialized(m)
225
- },
226
- merge: mergeMessage,
227
- }
228
- }
229
- }
230
-
231
- func sizeMessageInfo(p pointer, f *coderFieldInfo, opts marshalOptions) int {
232
- return protowire.SizeBytes(f.mi.sizePointer(p.Elem(), opts)) + f.tagsize
233
- }
234
-
235
- func appendMessageInfo(b []byte, p pointer, f *coderFieldInfo, opts marshalOptions) ([]byte, error) {
236
- b = protowire.AppendVarint(b, f.wiretag)
237
- b = protowire.AppendVarint(b, uint64(f.mi.sizePointer(p.Elem(), opts)))
238
- return f.mi.marshalAppendPointer(b, p.Elem(), opts)
239
- }
240
-
241
- func consumeMessageInfo(b []byte, p pointer, wtyp protowire.Type, f *coderFieldInfo, opts unmarshalOptions) (out unmarshalOutput, err error) {
242
- if wtyp != protowire.BytesType {
243
- return out, errUnknown
244
- }
245
- v, n := protowire.ConsumeBytes(b)
246
- if n < 0 {
247
- return out, errDecode
248
- }
249
- if p.Elem().IsNil() {
250
- p.SetPointer(pointerOfValue(reflect.New(f.mi.GoReflectType.Elem())))
251
- }
252
- o, err := f.mi.unmarshalPointer(v, p.Elem(), 0, opts)
253
- if err != nil {
254
- return out, err
255
- }
256
- out.n = n
257
- out.initialized = o.initialized
258
- return out, nil
259
- }
260
-
261
- func isInitMessageInfo(p pointer, f *coderFieldInfo) error {
262
- return f.mi.checkInitializedPointer(p.Elem())
263
- }
264
-
265
- func sizeMessage(m proto.Message, tagsize int, _ marshalOptions) int {
266
- return protowire.SizeBytes(proto.Size(m)) + tagsize
267
- }
268
-
269
- func appendMessage(b []byte, m proto.Message, wiretag uint64, opts marshalOptions) ([]byte, error) {
270
- b = protowire.AppendVarint(b, wiretag)
271
- b = protowire.AppendVarint(b, uint64(proto.Size(m)))
272
- return opts.Options().MarshalAppend(b, m)
273
- }
274
-
275
- func consumeMessage(b []byte, m proto.Message, wtyp protowire.Type, opts unmarshalOptions) (out unmarshalOutput, err error) {
276
- if wtyp != protowire.BytesType {
277
- return out, errUnknown
278
- }
279
- v, n := protowire.ConsumeBytes(b)
280
- if n < 0 {
281
- return out, errDecode
282
- }
283
- o, err := opts.Options().UnmarshalState(piface.UnmarshalInput{
284
- Buf: v,
285
- Message: m.ProtoReflect(),
286
- })
287
- if err != nil {
288
- return out, err
289
- }
290
- out.n = n
291
- out.initialized = o.Flags&piface.UnmarshalInitialized != 0
292
- return out, nil
293
- }
294
-
295
- func sizeMessageValue(v pref.Value, tagsize int, opts marshalOptions) int {
296
- m := v.Message().Interface()
297
- return sizeMessage(m, tagsize, opts)
298
- }
299
-
300
- func appendMessageValue(b []byte, v pref.Value, wiretag uint64, opts marshalOptions) ([]byte, error) {
301
- m := v.Message().Interface()
302
- return appendMessage(b, m, wiretag, opts)
303
- }
304
-
305
- func consumeMessageValue(b []byte, v pref.Value, _ protowire.Number, wtyp protowire.Type, opts unmarshalOptions) (pref.Value, unmarshalOutput, error) {
306
- m := v.Message().Interface()
307
- out, err := consumeMessage(b, m, wtyp, opts)
308
- return v, out, err
309
- }
310
-
311
- func isInitMessageValue(v pref.Value) error {
312
- m := v.Message().Interface()
313
- return proto.CheckInitialized(m)
314
- }
315
-
316
- var coderMessageValue = valueCoderFuncs{
317
- size: sizeMessageValue,
318
- marshal: appendMessageValue,
319
- unmarshal: consumeMessageValue,
320
- isInit: isInitMessageValue,
321
- merge: mergeMessageValue,
322
- }
323
-
324
- func sizeGroupValue(v pref.Value, tagsize int, opts marshalOptions) int {
325
- m := v.Message().Interface()
326
- return sizeGroup(m, tagsize, opts)
327
- }
328
-
329
- func appendGroupValue(b []byte, v pref.Value, wiretag uint64, opts marshalOptions) ([]byte, error) {
330
- m := v.Message().Interface()
331
- return appendGroup(b, m, wiretag, opts)
332
- }
333
-
334
- func consumeGroupValue(b []byte, v pref.Value, num protowire.Number, wtyp protowire.Type, opts unmarshalOptions) (pref.Value, unmarshalOutput, error) {
335
- m := v.Message().Interface()
336
- out, err := consumeGroup(b, m, num, wtyp, opts)
337
- return v, out, err
338
- }
339
-
340
- var coderGroupValue = valueCoderFuncs{
341
- size: sizeGroupValue,
342
- marshal: appendGroupValue,
343
- unmarshal: consumeGroupValue,
344
- isInit: isInitMessageValue,
345
- merge: mergeMessageValue,
346
- }
347
-
348
- func makeGroupFieldCoder(fd pref.FieldDescriptor, ft reflect.Type) pointerCoderFuncs {
349
- num := fd.Number()
350
- if mi := getMessageInfo(ft); mi != nil {
351
- funcs := pointerCoderFuncs{
352
- size: sizeGroupType,
353
- marshal: appendGroupType,
354
- unmarshal: consumeGroupType,
355
- merge: mergeMessage,
356
- }
357
- if needsInitCheck(mi.Desc) {
358
- funcs.isInit = isInitMessageInfo
359
- }
360
- return funcs
361
- } else {
362
- return pointerCoderFuncs{
363
- size: func(p pointer, f *coderFieldInfo, opts marshalOptions) int {
364
- m := asMessage(p.AsValueOf(ft).Elem())
365
- return sizeGroup(m, f.tagsize, opts)
366
- },
367
- marshal: func(b []byte, p pointer, f *coderFieldInfo, opts marshalOptions) ([]byte, error) {
368
- m := asMessage(p.AsValueOf(ft).Elem())
369
- return appendGroup(b, m, f.wiretag, opts)
370
- },
371
- unmarshal: func(b []byte, p pointer, wtyp protowire.Type, f *coderFieldInfo, opts unmarshalOptions) (unmarshalOutput, error) {
372
- mp := p.AsValueOf(ft).Elem()
373
- if mp.IsNil() {
374
- mp.Set(reflect.New(ft.Elem()))
375
- }
376
- return consumeGroup(b, asMessage(mp), num, wtyp, opts)
377
- },
378
- isInit: func(p pointer, f *coderFieldInfo) error {
379
- m := asMessage(p.AsValueOf(ft).Elem())
380
- return proto.CheckInitialized(m)
381
- },
382
- merge: mergeMessage,
383
- }
384
- }
385
- }
386
-
387
- func sizeGroupType(p pointer, f *coderFieldInfo, opts marshalOptions) int {
388
- return 2*f.tagsize + f.mi.sizePointer(p.Elem(), opts)
389
- }
390
-
391
- func appendGroupType(b []byte, p pointer, f *coderFieldInfo, opts marshalOptions) ([]byte, error) {
392
- b = protowire.AppendVarint(b, f.wiretag) // start group
393
- b, err := f.mi.marshalAppendPointer(b, p.Elem(), opts)
394
- b = protowire.AppendVarint(b, f.wiretag+1) // end group
395
- return b, err
396
- }
397
-
398
- func consumeGroupType(b []byte, p pointer, wtyp protowire.Type, f *coderFieldInfo, opts unmarshalOptions) (out unmarshalOutput, err error) {
399
- if wtyp != protowire.StartGroupType {
400
- return out, errUnknown
401
- }
402
- if p.Elem().IsNil() {
403
- p.SetPointer(pointerOfValue(reflect.New(f.mi.GoReflectType.Elem())))
404
- }
405
- return f.mi.unmarshalPointer(b, p.Elem(), f.num, opts)
406
- }
407
-
408
- func sizeGroup(m proto.Message, tagsize int, _ marshalOptions) int {
409
- return 2*tagsize + proto.Size(m)
410
- }
411
-
412
- func appendGroup(b []byte, m proto.Message, wiretag uint64, opts marshalOptions) ([]byte, error) {
413
- b = protowire.AppendVarint(b, wiretag) // start group
414
- b, err := opts.Options().MarshalAppend(b, m)
415
- b = protowire.AppendVarint(b, wiretag+1) // end group
416
- return b, err
417
- }
418
-
419
- func consumeGroup(b []byte, m proto.Message, num protowire.Number, wtyp protowire.Type, opts unmarshalOptions) (out unmarshalOutput, err error) {
420
- if wtyp != protowire.StartGroupType {
421
- return out, errUnknown
422
- }
423
- b, n := protowire.ConsumeGroup(num, b)
424
- if n < 0 {
425
- return out, errDecode
426
- }
427
- o, err := opts.Options().UnmarshalState(piface.UnmarshalInput{
428
- Buf: b,
429
- Message: m.ProtoReflect(),
430
- })
431
- if err != nil {
432
- return out, err
433
- }
434
- out.n = n
435
- out.initialized = o.Flags&piface.UnmarshalInitialized != 0
436
- return out, nil
437
- }
438
-
439
- func makeMessageSliceFieldCoder(fd pref.FieldDescriptor, ft reflect.Type) pointerCoderFuncs {
440
- if mi := getMessageInfo(ft); mi != nil {
441
- funcs := pointerCoderFuncs{
442
- size: sizeMessageSliceInfo,
443
- marshal: appendMessageSliceInfo,
444
- unmarshal: consumeMessageSliceInfo,
445
- merge: mergeMessageSlice,
446
- }
447
- if needsInitCheck(mi.Desc) {
448
- funcs.isInit = isInitMessageSliceInfo
449
- }
450
- return funcs
451
- }
452
- return pointerCoderFuncs{
453
- size: func(p pointer, f *coderFieldInfo, opts marshalOptions) int {
454
- return sizeMessageSlice(p, ft, f.tagsize, opts)
455
- },
456
- marshal: func(b []byte, p pointer, f *coderFieldInfo, opts marshalOptions) ([]byte, error) {
457
- return appendMessageSlice(b, p, f.wiretag, ft, opts)
458
- },
459
- unmarshal: func(b []byte, p pointer, wtyp protowire.Type, f *coderFieldInfo, opts unmarshalOptions) (unmarshalOutput, error) {
460
- return consumeMessageSlice(b, p, ft, wtyp, opts)
461
- },
462
- isInit: func(p pointer, f *coderFieldInfo) error {
463
- return isInitMessageSlice(p, ft)
464
- },
465
- merge: mergeMessageSlice,
466
- }
467
- }
468
-
469
- func sizeMessageSliceInfo(p pointer, f *coderFieldInfo, opts marshalOptions) int {
470
- s := p.PointerSlice()
471
- n := 0
472
- for _, v := range s {
473
- n += protowire.SizeBytes(f.mi.sizePointer(v, opts)) + f.tagsize
474
- }
475
- return n
476
- }
477
-
478
- func appendMessageSliceInfo(b []byte, p pointer, f *coderFieldInfo, opts marshalOptions) ([]byte, error) {
479
- s := p.PointerSlice()
480
- var err error
481
- for _, v := range s {
482
- b = protowire.AppendVarint(b, f.wiretag)
483
- siz := f.mi.sizePointer(v, opts)
484
- b = protowire.AppendVarint(b, uint64(siz))
485
- b, err = f.mi.marshalAppendPointer(b, v, opts)
486
- if err != nil {
487
- return b, err
488
- }
489
- }
490
- return b, nil
491
- }
492
-
493
- func consumeMessageSliceInfo(b []byte, p pointer, wtyp protowire.Type, f *coderFieldInfo, opts unmarshalOptions) (out unmarshalOutput, err error) {
494
- if wtyp != protowire.BytesType {
495
- return out, errUnknown
496
- }
497
- v, n := protowire.ConsumeBytes(b)
498
- if n < 0 {
499
- return out, errDecode
500
- }
501
- m := reflect.New(f.mi.GoReflectType.Elem()).Interface()
502
- mp := pointerOfIface(m)
503
- o, err := f.mi.unmarshalPointer(v, mp, 0, opts)
504
- if err != nil {
505
- return out, err
506
- }
507
- p.AppendPointerSlice(mp)
508
- out.n = n
509
- out.initialized = o.initialized
510
- return out, nil
511
- }
512
-
513
- func isInitMessageSliceInfo(p pointer, f *coderFieldInfo) error {
514
- s := p.PointerSlice()
515
- for _, v := range s {
516
- if err := f.mi.checkInitializedPointer(v); err != nil {
517
- return err
518
- }
519
- }
520
- return nil
521
- }
522
-
523
- func sizeMessageSlice(p pointer, goType reflect.Type, tagsize int, _ marshalOptions) int {
524
- s := p.PointerSlice()
525
- n := 0
526
- for _, v := range s {
527
- m := asMessage(v.AsValueOf(goType.Elem()))
528
- n += protowire.SizeBytes(proto.Size(m)) + tagsize
529
- }
530
- return n
531
- }
532
-
533
- func appendMessageSlice(b []byte, p pointer, wiretag uint64, goType reflect.Type, opts marshalOptions) ([]byte, error) {
534
- s := p.PointerSlice()
535
- var err error
536
- for _, v := range s {
537
- m := asMessage(v.AsValueOf(goType.Elem()))
538
- b = protowire.AppendVarint(b, wiretag)
539
- siz := proto.Size(m)
540
- b = protowire.AppendVarint(b, uint64(siz))
541
- b, err = opts.Options().MarshalAppend(b, m)
542
- if err != nil {
543
- return b, err
544
- }
545
- }
546
- return b, nil
547
- }
548
-
549
- func consumeMessageSlice(b []byte, p pointer, goType reflect.Type, wtyp protowire.Type, opts unmarshalOptions) (out unmarshalOutput, err error) {
550
- if wtyp != protowire.BytesType {
551
- return out, errUnknown
552
- }
553
- v, n := protowire.ConsumeBytes(b)
554
- if n < 0 {
555
- return out, errDecode
556
- }
557
- mp := reflect.New(goType.Elem())
558
- o, err := opts.Options().UnmarshalState(piface.UnmarshalInput{
559
- Buf: v,
560
- Message: asMessage(mp).ProtoReflect(),
561
- })
562
- if err != nil {
563
- return out, err
564
- }
565
- p.AppendPointerSlice(pointerOfValue(mp))
566
- out.n = n
567
- out.initialized = o.Flags&piface.UnmarshalInitialized != 0
568
- return out, nil
569
- }
570
-
571
- func isInitMessageSlice(p pointer, goType reflect.Type) error {
572
- s := p.PointerSlice()
573
- for _, v := range s {
574
- m := asMessage(v.AsValueOf(goType.Elem()))
575
- if err := proto.CheckInitialized(m); err != nil {
576
- return err
577
- }
578
- }
579
- return nil
580
- }
581
-
582
- // Slices of messages
583
-
584
- func sizeMessageSliceValue(listv pref.Value, tagsize int, opts marshalOptions) int {
585
- list := listv.List()
586
- n := 0
587
- for i, llen := 0, list.Len(); i < llen; i++ {
588
- m := list.Get(i).Message().Interface()
589
- n += protowire.SizeBytes(proto.Size(m)) + tagsize
590
- }
591
- return n
592
- }
593
-
594
- func appendMessageSliceValue(b []byte, listv pref.Value, wiretag uint64, opts marshalOptions) ([]byte, error) {
595
- list := listv.List()
596
- mopts := opts.Options()
597
- for i, llen := 0, list.Len(); i < llen; i++ {
598
- m := list.Get(i).Message().Interface()
599
- b = protowire.AppendVarint(b, wiretag)
600
- siz := proto.Size(m)
601
- b = protowire.AppendVarint(b, uint64(siz))
602
- var err error
603
- b, err = mopts.MarshalAppend(b, m)
604
- if err != nil {
605
- return b, err
606
- }
607
- }
608
- return b, nil
609
- }
610
-
611
- func consumeMessageSliceValue(b []byte, listv pref.Value, _ protowire.Number, wtyp protowire.Type, opts unmarshalOptions) (_ pref.Value, out unmarshalOutput, err error) {
612
- list := listv.List()
613
- if wtyp != protowire.BytesType {
614
- return pref.Value{}, out, errUnknown
615
- }
616
- v, n := protowire.ConsumeBytes(b)
617
- if n < 0 {
618
- return pref.Value{}, out, errDecode
619
- }
620
- m := list.NewElement()
621
- o, err := opts.Options().UnmarshalState(piface.UnmarshalInput{
622
- Buf: v,
623
- Message: m.Message(),
624
- })
625
- if err != nil {
626
- return pref.Value{}, out, err
627
- }
628
- list.Append(m)
629
- out.n = n
630
- out.initialized = o.Flags&piface.UnmarshalInitialized != 0
631
- return listv, out, nil
632
- }
633
-
634
- func isInitMessageSliceValue(listv pref.Value) error {
635
- list := listv.List()
636
- for i, llen := 0, list.Len(); i < llen; i++ {
637
- m := list.Get(i).Message().Interface()
638
- if err := proto.CheckInitialized(m); err != nil {
639
- return err
640
- }
641
- }
642
- return nil
643
- }
644
-
645
- var coderMessageSliceValue = valueCoderFuncs{
646
- size: sizeMessageSliceValue,
647
- marshal: appendMessageSliceValue,
648
- unmarshal: consumeMessageSliceValue,
649
- isInit: isInitMessageSliceValue,
650
- merge: mergeMessageListValue,
651
- }
652
-
653
- func sizeGroupSliceValue(listv pref.Value, tagsize int, opts marshalOptions) int {
654
- list := listv.List()
655
- n := 0
656
- for i, llen := 0, list.Len(); i < llen; i++ {
657
- m := list.Get(i).Message().Interface()
658
- n += 2*tagsize + proto.Size(m)
659
- }
660
- return n
661
- }
662
-
663
- func appendGroupSliceValue(b []byte, listv pref.Value, wiretag uint64, opts marshalOptions) ([]byte, error) {
664
- list := listv.List()
665
- mopts := opts.Options()
666
- for i, llen := 0, list.Len(); i < llen; i++ {
667
- m := list.Get(i).Message().Interface()
668
- b = protowire.AppendVarint(b, wiretag) // start group
669
- var err error
670
- b, err = mopts.MarshalAppend(b, m)
671
- if err != nil {
672
- return b, err
673
- }
674
- b = protowire.AppendVarint(b, wiretag+1) // end group
675
- }
676
- return b, nil
677
- }
678
-
679
- func consumeGroupSliceValue(b []byte, listv pref.Value, num protowire.Number, wtyp protowire.Type, opts unmarshalOptions) (_ pref.Value, out unmarshalOutput, err error) {
680
- list := listv.List()
681
- if wtyp != protowire.StartGroupType {
682
- return pref.Value{}, out, errUnknown
683
- }
684
- b, n := protowire.ConsumeGroup(num, b)
685
- if n < 0 {
686
- return pref.Value{}, out, errDecode
687
- }
688
- m := list.NewElement()
689
- o, err := opts.Options().UnmarshalState(piface.UnmarshalInput{
690
- Buf: b,
691
- Message: m.Message(),
692
- })
693
- if err != nil {
694
- return pref.Value{}, out, err
695
- }
696
- list.Append(m)
697
- out.n = n
698
- out.initialized = o.Flags&piface.UnmarshalInitialized != 0
699
- return listv, out, nil
700
- }
701
-
702
- var coderGroupSliceValue = valueCoderFuncs{
703
- size: sizeGroupSliceValue,
704
- marshal: appendGroupSliceValue,
705
- unmarshal: consumeGroupSliceValue,
706
- isInit: isInitMessageSliceValue,
707
- merge: mergeMessageListValue,
708
- }
709
-
710
- func makeGroupSliceFieldCoder(fd pref.FieldDescriptor, ft reflect.Type) pointerCoderFuncs {
711
- num := fd.Number()
712
- if mi := getMessageInfo(ft); mi != nil {
713
- funcs := pointerCoderFuncs{
714
- size: sizeGroupSliceInfo,
715
- marshal: appendGroupSliceInfo,
716
- unmarshal: consumeGroupSliceInfo,
717
- merge: mergeMessageSlice,
718
- }
719
- if needsInitCheck(mi.Desc) {
720
- funcs.isInit = isInitMessageSliceInfo
721
- }
722
- return funcs
723
- }
724
- return pointerCoderFuncs{
725
- size: func(p pointer, f *coderFieldInfo, opts marshalOptions) int {
726
- return sizeGroupSlice(p, ft, f.tagsize, opts)
727
- },
728
- marshal: func(b []byte, p pointer, f *coderFieldInfo, opts marshalOptions) ([]byte, error) {
729
- return appendGroupSlice(b, p, f.wiretag, ft, opts)
730
- },
731
- unmarshal: func(b []byte, p pointer, wtyp protowire.Type, f *coderFieldInfo, opts unmarshalOptions) (unmarshalOutput, error) {
732
- return consumeGroupSlice(b, p, num, wtyp, ft, opts)
733
- },
734
- isInit: func(p pointer, f *coderFieldInfo) error {
735
- return isInitMessageSlice(p, ft)
736
- },
737
- merge: mergeMessageSlice,
738
- }
739
- }
740
-
741
- func sizeGroupSlice(p pointer, messageType reflect.Type, tagsize int, _ marshalOptions) int {
742
- s := p.PointerSlice()
743
- n := 0
744
- for _, v := range s {
745
- m := asMessage(v.AsValueOf(messageType.Elem()))
746
- n += 2*tagsize + proto.Size(m)
747
- }
748
- return n
749
- }
750
-
751
- func appendGroupSlice(b []byte, p pointer, wiretag uint64, messageType reflect.Type, opts marshalOptions) ([]byte, error) {
752
- s := p.PointerSlice()
753
- var err error
754
- for _, v := range s {
755
- m := asMessage(v.AsValueOf(messageType.Elem()))
756
- b = protowire.AppendVarint(b, wiretag) // start group
757
- b, err = opts.Options().MarshalAppend(b, m)
758
- if err != nil {
759
- return b, err
760
- }
761
- b = protowire.AppendVarint(b, wiretag+1) // end group
762
- }
763
- return b, nil
764
- }
765
-
766
- func consumeGroupSlice(b []byte, p pointer, num protowire.Number, wtyp protowire.Type, goType reflect.Type, opts unmarshalOptions) (out unmarshalOutput, err error) {
767
- if wtyp != protowire.StartGroupType {
768
- return out, errUnknown
769
- }
770
- b, n := protowire.ConsumeGroup(num, b)
771
- if n < 0 {
772
- return out, errDecode
773
- }
774
- mp := reflect.New(goType.Elem())
775
- o, err := opts.Options().UnmarshalState(piface.UnmarshalInput{
776
- Buf: b,
777
- Message: asMessage(mp).ProtoReflect(),
778
- })
779
- if err != nil {
780
- return out, err
781
- }
782
- p.AppendPointerSlice(pointerOfValue(mp))
783
- out.n = n
784
- out.initialized = o.Flags&piface.UnmarshalInitialized != 0
785
- return out, nil
786
- }
787
-
788
- func sizeGroupSliceInfo(p pointer, f *coderFieldInfo, opts marshalOptions) int {
789
- s := p.PointerSlice()
790
- n := 0
791
- for _, v := range s {
792
- n += 2*f.tagsize + f.mi.sizePointer(v, opts)
793
- }
794
- return n
795
- }
796
-
797
- func appendGroupSliceInfo(b []byte, p pointer, f *coderFieldInfo, opts marshalOptions) ([]byte, error) {
798
- s := p.PointerSlice()
799
- var err error
800
- for _, v := range s {
801
- b = protowire.AppendVarint(b, f.wiretag) // start group
802
- b, err = f.mi.marshalAppendPointer(b, v, opts)
803
- if err != nil {
804
- return b, err
805
- }
806
- b = protowire.AppendVarint(b, f.wiretag+1) // end group
807
- }
808
- return b, nil
809
- }
810
-
811
- func consumeGroupSliceInfo(b []byte, p pointer, wtyp protowire.Type, f *coderFieldInfo, opts unmarshalOptions) (unmarshalOutput, error) {
812
- if wtyp != protowire.StartGroupType {
813
- return unmarshalOutput{}, errUnknown
814
- }
815
- m := reflect.New(f.mi.GoReflectType.Elem()).Interface()
816
- mp := pointerOfIface(m)
817
- out, err := f.mi.unmarshalPointer(b, mp, f.num, opts)
818
- if err != nil {
819
- return out, err
820
- }
821
- p.AppendPointerSlice(mp)
822
- return out, nil
823
- }
824
-
825
- func asMessage(v reflect.Value) pref.ProtoMessage {
826
- if m, ok := v.Interface().(pref.ProtoMessage); ok {
827
- return m
828
- }
829
- return legacyWrapMessage(v).Interface()
830
- }