arrow.proto 1.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657
  1. // Copyright 2021 Google LLC
  2. //
  3. // Licensed under the Apache License, Version 2.0 (the "License");
  4. // you may not use this file except in compliance with the License.
  5. // You may obtain a copy of the License at
  6. //
  7. // http://www.apache.org/licenses/LICENSE-2.0
  8. //
  9. // Unless required by applicable law or agreed to in writing, software
  10. // distributed under the License is distributed on an "AS IS" BASIS,
  11. // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
  12. // See the License for the specific language governing permissions and
  13. // limitations under the License.
  14. syntax = "proto3";
  15. package google.cloud.bigquery.storage.v1beta2;
  16. option go_package = "google.golang.org/genproto/googleapis/cloud/bigquery/storage/v1beta2;storage";
  17. option java_multiple_files = true;
  18. option java_outer_classname = "ArrowProto";
  19. option java_package = "com.google.cloud.bigquery.storage.v1beta2";
  20. // Arrow schema as specified in
  21. // https://arrow.apache.org/docs/python/api/datatypes.html
  22. // and serialized to bytes using IPC:
  23. // https://arrow.apache.org/docs/format/Columnar.html#serialization-and-interprocess-communication-ipc
  24. //
  25. // See code samples on how this message can be deserialized.
  26. message ArrowSchema {
  27. // IPC serialized Arrow schema.
  28. bytes serialized_schema = 1;
  29. }
  30. // Arrow RecordBatch.
  31. message ArrowRecordBatch {
  32. // IPC-serialized Arrow RecordBatch.
  33. bytes serialized_record_batch = 1;
  34. }
  35. // Contains options specific to Arrow Serialization.
  36. message ArrowSerializationOptions {
  37. // The IPC format to use when serializing Arrow streams.
  38. enum Format {
  39. // If unspecied the IPC format as of 0.15 release will be used.
  40. FORMAT_UNSPECIFIED = 0;
  41. // Use the legacy IPC message format as of Apache Arrow Release 0.14.
  42. ARROW_0_14 = 1;
  43. // Use the message format as of Apache Arrow Release 0.15.
  44. ARROW_0_15 = 2;
  45. }
  46. // The Arrow IPC format to use.
  47. Format format = 1;
  48. }