google-protobuf 3.19.1 → 4.30.2
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.
- checksums.yaml +4 -4
- data/ext/google/protobuf_c/Rakefile +3 -0
- data/ext/google/protobuf_c/convert.c +153 -166
- data/ext/google/protobuf_c/convert.h +15 -37
- data/ext/google/protobuf_c/defs.c +867 -251
- data/ext/google/protobuf_c/defs.h +22 -47
- data/ext/google/protobuf_c/extconf.rb +25 -5
- data/ext/google/protobuf_c/glue.c +135 -0
- data/ext/google/protobuf_c/map.c +182 -145
- data/ext/google/protobuf_c/map.h +16 -35
- data/ext/google/protobuf_c/message.c +534 -437
- data/ext/google/protobuf_c/message.h +30 -49
- data/ext/google/protobuf_c/protobuf.c +125 -238
- data/ext/google/protobuf_c/protobuf.h +40 -49
- data/ext/google/protobuf_c/repeated_field.c +152 -120
- data/ext/google/protobuf_c/repeated_field.h +16 -34
- data/ext/google/protobuf_c/ruby-upb.c +15827 -7228
- data/ext/google/protobuf_c/ruby-upb.h +15075 -3866
- data/ext/google/protobuf_c/shared_convert.c +69 -0
- data/ext/google/protobuf_c/shared_convert.h +26 -0
- data/ext/google/protobuf_c/shared_message.c +37 -0
- data/ext/google/protobuf_c/shared_message.h +21 -0
- data/ext/google/protobuf_c/third_party/utf8_range/LICENSE +22 -0
- data/ext/google/protobuf_c/third_party/utf8_range/utf8_range.c +207 -0
- data/ext/google/protobuf_c/third_party/utf8_range/utf8_range.h +22 -0
- data/ext/google/protobuf_c/third_party/utf8_range/utf8_range_neon.inc +117 -0
- data/ext/google/protobuf_c/third_party/utf8_range/utf8_range_sse.inc +272 -0
- data/ext/google/protobuf_c/wrap_memcpy.c +7 -29
- data/lib/google/protobuf/any_pb.rb +6 -8
- data/lib/google/protobuf/api_pb.rb +6 -26
- data/lib/google/protobuf/descriptor_pb.rb +24 -225
- data/lib/google/protobuf/duration_pb.rb +6 -8
- data/lib/google/protobuf/empty_pb.rb +6 -6
- data/lib/google/protobuf/ffi/descriptor.rb +175 -0
- data/lib/google/protobuf/ffi/descriptor_pool.rb +77 -0
- data/lib/google/protobuf/ffi/enum_descriptor.rb +183 -0
- data/lib/google/protobuf/ffi/ffi.rb +214 -0
- data/lib/google/protobuf/ffi/field_descriptor.rb +340 -0
- data/lib/google/protobuf/ffi/file_descriptor.rb +59 -0
- data/lib/google/protobuf/ffi/internal/arena.rb +60 -0
- data/lib/google/protobuf/ffi/internal/convert.rb +292 -0
- data/lib/google/protobuf/ffi/internal/pointer_helper.rb +35 -0
- data/lib/google/protobuf/ffi/internal/type_safety.rb +25 -0
- data/lib/google/protobuf/ffi/map.rb +433 -0
- data/lib/google/protobuf/ffi/message.rb +783 -0
- data/lib/google/protobuf/ffi/method_descriptor.rb +124 -0
- data/lib/google/protobuf/ffi/object_cache.rb +30 -0
- data/lib/google/protobuf/ffi/oneof_descriptor.rb +107 -0
- data/lib/google/protobuf/ffi/repeated_field.rb +411 -0
- data/lib/google/protobuf/ffi/service_descriptor.rb +117 -0
- data/lib/google/protobuf/field_mask_pb.rb +6 -7
- data/lib/google/protobuf/internal/object_cache.rb +99 -0
- data/lib/google/protobuf/message_exts.rb +10 -28
- data/lib/google/protobuf/plugin_pb.rb +25 -0
- data/lib/google/protobuf/repeated_field.rb +22 -33
- data/lib/google/protobuf/source_context_pb.rb +6 -7
- data/lib/google/protobuf/struct_pb.rb +6 -23
- data/lib/google/protobuf/timestamp_pb.rb +6 -8
- data/lib/google/protobuf/type_pb.rb +6 -71
- data/lib/google/protobuf/well_known_types.rb +16 -40
- data/lib/google/protobuf/wrappers_pb.rb +6 -31
- data/lib/google/protobuf.rb +32 -50
- data/lib/google/protobuf_ffi.rb +52 -0
- data/lib/google/protobuf_native.rb +19 -0
- data/lib/google/tasks/ffi.rake +100 -0
- metadata +97 -20
- data/lib/google/protobuf/descriptor_dsl.rb +0 -458
- data/tests/basic.rb +0 -640
- data/tests/generated_code_test.rb +0 -23
- data/tests/stress.rb +0 -38
@@ -1,38 +1,13 @@
|
|
1
1
|
// Protocol Buffers - Google's data interchange format
|
2
2
|
// Copyright 2008 Google Inc. All rights reserved.
|
3
|
-
// https://developers.google.com/protocol-buffers/
|
4
3
|
//
|
5
|
-
//
|
6
|
-
//
|
7
|
-
//
|
8
|
-
//
|
9
|
-
// * Redistributions of source code must retain the above copyright
|
10
|
-
// notice, this list of conditions and the following disclaimer.
|
11
|
-
// * Redistributions in binary form must reproduce the above
|
12
|
-
// copyright notice, this list of conditions and the following disclaimer
|
13
|
-
// in the documentation and/or other materials provided with the
|
14
|
-
// distribution.
|
15
|
-
// * Neither the name of Google Inc. nor the names of its
|
16
|
-
// contributors may be used to endorse or promote products derived from
|
17
|
-
// this software without specific prior written permission.
|
18
|
-
//
|
19
|
-
// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
|
20
|
-
// "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
|
21
|
-
// LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
|
22
|
-
// A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
|
23
|
-
// OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
|
24
|
-
// SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
|
25
|
-
// LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
|
26
|
-
// DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
|
27
|
-
// THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
|
28
|
-
// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
|
29
|
-
// OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
|
4
|
+
// Use of this source code is governed by a BSD-style
|
5
|
+
// license that can be found in the LICENSE file or at
|
6
|
+
// https://developers.google.com/open-source/licenses/bsd
|
30
7
|
|
31
8
|
#ifndef RUBY_PROTOBUF_DEFS_H_
|
32
9
|
#define RUBY_PROTOBUF_DEFS_H_
|
33
10
|
|
34
|
-
#include <ruby/ruby.h>
|
35
|
-
|
36
11
|
#include "protobuf.h"
|
37
12
|
#include "ruby-upb.h"
|
38
13
|
|
@@ -40,9 +15,9 @@
|
|
40
15
|
// TypeInfo
|
41
16
|
// -----------------------------------------------------------------------------
|
42
17
|
|
43
|
-
// This bundles a
|
18
|
+
// This bundles a upb_CType and msgdef/enumdef when appropriate. This is
|
44
19
|
// convenient for functions that need type information but cannot necessarily
|
45
|
-
// assume a
|
20
|
+
// assume a upb_FieldDef will be available.
|
46
21
|
//
|
47
22
|
// For example, Google::Protobuf::Map and Google::Protobuf::RepeatedField can
|
48
23
|
// be constructed with type information alone:
|
@@ -51,21 +26,21 @@
|
|
51
26
|
// Google::Protobuf::RepeatedField.new(:message, FooMessage)
|
52
27
|
|
53
28
|
typedef struct {
|
54
|
-
|
29
|
+
upb_CType type;
|
55
30
|
union {
|
56
|
-
const
|
57
|
-
const
|
31
|
+
const upb_MessageDef* msgdef; // When type == kUpb_CType_Message
|
32
|
+
const upb_EnumDef* enumdef; // When type == kUpb_CType_Enum
|
58
33
|
} def;
|
59
34
|
} TypeInfo;
|
60
35
|
|
61
|
-
static inline TypeInfo TypeInfo_get(const
|
62
|
-
TypeInfo ret = {
|
36
|
+
static inline TypeInfo TypeInfo_get(const upb_FieldDef* f) {
|
37
|
+
TypeInfo ret = {upb_FieldDef_CType(f), {NULL}};
|
63
38
|
switch (ret.type) {
|
64
|
-
case
|
65
|
-
ret.def.msgdef =
|
39
|
+
case kUpb_CType_Message:
|
40
|
+
ret.def.msgdef = upb_FieldDef_MessageSubDef(f);
|
66
41
|
break;
|
67
|
-
case
|
68
|
-
ret.def.enumdef =
|
42
|
+
case kUpb_CType_Enum:
|
43
|
+
ret.def.enumdef = upb_FieldDef_EnumSubDef(f);
|
69
44
|
break;
|
70
45
|
default:
|
71
46
|
break;
|
@@ -76,9 +51,9 @@ static inline TypeInfo TypeInfo_get(const upb_fielddef *f) {
|
|
76
51
|
TypeInfo TypeInfo_FromClass(int argc, VALUE* argv, int skip_arg,
|
77
52
|
VALUE* type_class, VALUE* init_arg);
|
78
53
|
|
79
|
-
static inline TypeInfo TypeInfo_from_type(
|
54
|
+
static inline TypeInfo TypeInfo_from_type(upb_CType type) {
|
80
55
|
TypeInfo ret = {type};
|
81
|
-
assert(type !=
|
56
|
+
assert(type != kUpb_CType_Message && type != kUpb_CType_Enum);
|
82
57
|
return ret;
|
83
58
|
}
|
84
59
|
|
@@ -86,17 +61,17 @@ static inline TypeInfo TypeInfo_from_type(upb_fieldtype_t type) {
|
|
86
61
|
// Other utilities
|
87
62
|
// -----------------------------------------------------------------------------
|
88
63
|
|
89
|
-
VALUE Descriptor_DefToClass(const
|
64
|
+
VALUE Descriptor_DefToClass(const upb_MessageDef* m);
|
90
65
|
|
91
66
|
// Returns the underlying msgdef, enumdef, or symtab (respectively) for the
|
92
67
|
// given Descriptor, EnumDescriptor, or DescriptorPool Ruby object.
|
93
|
-
const
|
94
|
-
const
|
95
|
-
const
|
68
|
+
const upb_EnumDef* EnumDescriptor_GetEnumDef(VALUE enum_desc_rb);
|
69
|
+
const upb_DefPool* DescriptorPool_GetSymtab(VALUE desc_pool_rb);
|
70
|
+
const upb_MessageDef* Descriptor_GetMsgDef(VALUE desc_rb);
|
96
71
|
|
97
72
|
// Returns a upb field type for the given Ruby symbol
|
98
|
-
// (eg. :float =>
|
99
|
-
|
73
|
+
// (eg. :float => kUpb_CType_Float).
|
74
|
+
upb_CType ruby_to_fieldtype(VALUE type);
|
100
75
|
|
101
76
|
// The singleton generated pool (a DescriptorPool object).
|
102
77
|
extern VALUE generated_pool;
|
@@ -2,19 +2,39 @@
|
|
2
2
|
|
3
3
|
require 'mkmf'
|
4
4
|
|
5
|
-
|
5
|
+
ext_name = "google/protobuf_c"
|
6
|
+
|
7
|
+
dir_config(ext_name)
|
8
|
+
|
9
|
+
if ENV["CC"]
|
10
|
+
RbConfig::CONFIG["CC"] = RbConfig::MAKEFILE_CONFIG["CC"] = ENV["CC"]
|
11
|
+
end
|
12
|
+
|
13
|
+
if ENV["CXX"]
|
14
|
+
RbConfig::CONFIG["CXX"] = RbConfig::MAKEFILE_CONFIG["CXX"] = ENV["CXX"]
|
15
|
+
end
|
16
|
+
|
17
|
+
if ENV["LD"]
|
18
|
+
RbConfig::CONFIG["LD"] = RbConfig::MAKEFILE_CONFIG["LD"] = ENV["LD"]
|
19
|
+
end
|
20
|
+
|
21
|
+
if RUBY_PLATFORM =~ /darwin/ || RUBY_PLATFORM =~ /linux/ || RUBY_PLATFORM =~ /freebsd/
|
6
22
|
$CFLAGS += " -std=gnu99 -O3 -DNDEBUG -fvisibility=hidden -Wall -Wsign-compare -Wno-declaration-after-statement"
|
7
23
|
else
|
8
24
|
$CFLAGS += " -std=gnu99 -O3 -DNDEBUG"
|
9
25
|
end
|
10
26
|
|
11
|
-
|
12
27
|
if RUBY_PLATFORM =~ /linux/
|
13
28
|
# Instruct the linker to point memcpy calls at our __wrap_memcpy wrapper.
|
14
29
|
$LDFLAGS += " -Wl,-wrap,memcpy"
|
15
30
|
end
|
16
31
|
|
17
|
-
$
|
18
|
-
|
32
|
+
$VPATH << "$(srcdir)/third_party/utf8_range"
|
33
|
+
$INCFLAGS += " -I$(srcdir)/third_party/utf8_range"
|
34
|
+
|
35
|
+
$srcs = ["protobuf.c", "convert.c", "defs.c", "message.c",
|
36
|
+
"repeated_field.c", "map.c", "ruby-upb.c", "wrap_memcpy.c",
|
37
|
+
"utf8_range.c", "shared_convert.c",
|
38
|
+
"shared_message.c"]
|
19
39
|
|
20
|
-
create_makefile(
|
40
|
+
create_makefile(ext_name)
|
@@ -0,0 +1,135 @@
|
|
1
|
+
// Protocol Buffers - Google's data interchange format
|
2
|
+
// Copyright 2023 Google Inc. All rights reserved.
|
3
|
+
//
|
4
|
+
// Use of this source code is governed by a BSD-style
|
5
|
+
// license that can be found in the LICENSE file or at
|
6
|
+
// https://developers.google.com/open-source/licenses/bsd
|
7
|
+
|
8
|
+
// -----------------------------------------------------------------------------
|
9
|
+
// Exposing inlined UPB functions. Strictly free of dependencies on
|
10
|
+
// Ruby interpreter internals.
|
11
|
+
|
12
|
+
#include "ruby-upb.h"
|
13
|
+
|
14
|
+
upb_Arena* Arena_create() { return upb_Arena_Init(NULL, 0, &upb_alloc_global); }
|
15
|
+
|
16
|
+
google_protobuf_FileDescriptorProto* FileDescriptorProto_parse(
|
17
|
+
const char* serialized_file_proto, size_t length, upb_Arena* arena) {
|
18
|
+
return google_protobuf_FileDescriptorProto_parse(serialized_file_proto,
|
19
|
+
length, arena);
|
20
|
+
}
|
21
|
+
|
22
|
+
char* EnumDescriptor_serialized_options(const upb_EnumDef* enumdef,
|
23
|
+
size_t* size, upb_Arena* arena) {
|
24
|
+
const google_protobuf_EnumOptions* opts = upb_EnumDef_Options(enumdef);
|
25
|
+
char* serialized = google_protobuf_EnumOptions_serialize(opts, arena, size);
|
26
|
+
return serialized;
|
27
|
+
}
|
28
|
+
|
29
|
+
char* EnumDescriptor_serialized_to_proto(const upb_EnumDef* enumdef,
|
30
|
+
size_t* size, upb_Arena* arena) {
|
31
|
+
const google_protobuf_EnumDescriptorProto* file_proto =
|
32
|
+
upb_EnumDef_ToProto(enumdef, arena);
|
33
|
+
char* serialized =
|
34
|
+
google_protobuf_EnumDescriptorProto_serialize(file_proto, arena, size);
|
35
|
+
return serialized;
|
36
|
+
}
|
37
|
+
|
38
|
+
char* FileDescriptor_serialized_options(const upb_FileDef* filedef,
|
39
|
+
size_t* size, upb_Arena* arena) {
|
40
|
+
const google_protobuf_FileOptions* opts = upb_FileDef_Options(filedef);
|
41
|
+
char* serialized = google_protobuf_FileOptions_serialize(opts, arena, size);
|
42
|
+
return serialized;
|
43
|
+
}
|
44
|
+
|
45
|
+
char* FileDescriptor_serialized_to_proto(const upb_FileDef* filedef,
|
46
|
+
size_t* size, upb_Arena* arena) {
|
47
|
+
const google_protobuf_FileDescriptorProto* file_proto =
|
48
|
+
upb_FileDef_ToProto(filedef, arena);
|
49
|
+
char* serialized =
|
50
|
+
google_protobuf_FileDescriptorProto_serialize(file_proto, arena, size);
|
51
|
+
return serialized;
|
52
|
+
}
|
53
|
+
|
54
|
+
char* Descriptor_serialized_options(const upb_MessageDef* msgdef, size_t* size,
|
55
|
+
upb_Arena* arena) {
|
56
|
+
const google_protobuf_MessageOptions* opts = upb_MessageDef_Options(msgdef);
|
57
|
+
char* serialized =
|
58
|
+
google_protobuf_MessageOptions_serialize(opts, arena, size);
|
59
|
+
return serialized;
|
60
|
+
}
|
61
|
+
|
62
|
+
char* Descriptor_serialized_to_proto(const upb_MessageDef* msgdef, size_t* size,
|
63
|
+
upb_Arena* arena) {
|
64
|
+
const google_protobuf_DescriptorProto* proto =
|
65
|
+
upb_MessageDef_ToProto(msgdef, arena);
|
66
|
+
char* serialized =
|
67
|
+
google_protobuf_DescriptorProto_serialize(proto, arena, size);
|
68
|
+
return serialized;
|
69
|
+
}
|
70
|
+
|
71
|
+
char* OneOfDescriptor_serialized_options(const upb_OneofDef* oneofdef,
|
72
|
+
size_t* size, upb_Arena* arena) {
|
73
|
+
const google_protobuf_OneofOptions* opts = upb_OneofDef_Options(oneofdef);
|
74
|
+
char* serialized = google_protobuf_OneofOptions_serialize(opts, arena, size);
|
75
|
+
return serialized;
|
76
|
+
}
|
77
|
+
|
78
|
+
char* OneOfDescriptor_serialized_to_proto(const upb_OneofDef* oneofdef,
|
79
|
+
size_t* size, upb_Arena* arena) {
|
80
|
+
const google_protobuf_OneofDescriptorProto* proto =
|
81
|
+
upb_OneofDef_ToProto(oneofdef, arena);
|
82
|
+
char* serialized =
|
83
|
+
google_protobuf_OneofDescriptorProto_serialize(proto, arena, size);
|
84
|
+
return serialized;
|
85
|
+
}
|
86
|
+
|
87
|
+
char* FieldDescriptor_serialized_options(const upb_FieldDef* fielddef,
|
88
|
+
size_t* size, upb_Arena* arena) {
|
89
|
+
const google_protobuf_FieldOptions* opts = upb_FieldDef_Options(fielddef);
|
90
|
+
char* serialized = google_protobuf_FieldOptions_serialize(opts, arena, size);
|
91
|
+
return serialized;
|
92
|
+
}
|
93
|
+
|
94
|
+
char* FieldDescriptor_serialized_to_proto(const upb_FieldDef* fieldef,
|
95
|
+
size_t* size, upb_Arena* arena) {
|
96
|
+
const google_protobuf_FieldDescriptorProto* proto =
|
97
|
+
upb_FieldDef_ToProto(fieldef, arena);
|
98
|
+
char* serialized =
|
99
|
+
google_protobuf_FieldDescriptorProto_serialize(proto, arena, size);
|
100
|
+
return serialized;
|
101
|
+
}
|
102
|
+
|
103
|
+
char* ServiceDescriptor_serialized_options(const upb_ServiceDef* servicedef,
|
104
|
+
size_t* size, upb_Arena* arena) {
|
105
|
+
const google_protobuf_ServiceOptions* opts =
|
106
|
+
upb_ServiceDef_Options(servicedef);
|
107
|
+
char* serialized =
|
108
|
+
google_protobuf_ServiceOptions_serialize(opts, arena, size);
|
109
|
+
return serialized;
|
110
|
+
}
|
111
|
+
|
112
|
+
char* ServiceDescriptor_serialized_to_proto(const upb_ServiceDef* servicedef,
|
113
|
+
size_t* size, upb_Arena* arena) {
|
114
|
+
const google_protobuf_ServiceDescriptorProto* proto =
|
115
|
+
upb_ServiceDef_ToProto(servicedef, arena);
|
116
|
+
char* serialized =
|
117
|
+
google_protobuf_ServiceDescriptorProto_serialize(proto, arena, size);
|
118
|
+
return serialized;
|
119
|
+
}
|
120
|
+
|
121
|
+
char* MethodDescriptor_serialized_options(const upb_MethodDef* methoddef,
|
122
|
+
size_t* size, upb_Arena* arena) {
|
123
|
+
const google_protobuf_MethodOptions* opts = upb_MethodDef_Options(methoddef);
|
124
|
+
char* serialized = google_protobuf_MethodOptions_serialize(opts, arena, size);
|
125
|
+
return serialized;
|
126
|
+
}
|
127
|
+
|
128
|
+
char* MethodDescriptor_serialized_to_proto(const upb_MethodDef* methodef,
|
129
|
+
size_t* size, upb_Arena* arena) {
|
130
|
+
const google_protobuf_MethodDescriptorProto* proto =
|
131
|
+
upb_MethodDef_ToProto(methodef, arena);
|
132
|
+
char* serialized =
|
133
|
+
google_protobuf_MethodDescriptorProto_serialize(proto, arena, size);
|
134
|
+
return serialized;
|
135
|
+
}
|