google-protobuf 3.17.2 → 3.23.4
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.
Potentially problematic release.
This version of google-protobuf might be problematic. Click here for more details.
- checksums.yaml +4 -4
- data/ext/google/protobuf_c/convert.c +128 -116
- data/ext/google/protobuf_c/convert.h +12 -9
- data/ext/google/protobuf_c/defs.c +235 -1529
- data/ext/google/protobuf_c/defs.h +19 -19
- data/ext/google/protobuf_c/extconf.rb +12 -6
- data/ext/google/protobuf_c/map.c +105 -109
- data/ext/google/protobuf_c/map.h +7 -8
- data/ext/google/protobuf_c/message.c +447 -342
- data/ext/google/protobuf_c/message.h +22 -19
- data/ext/google/protobuf_c/protobuf.c +71 -59
- data/ext/google/protobuf_c/protobuf.h +13 -10
- data/ext/google/protobuf_c/repeated_field.c +83 -85
- data/ext/google/protobuf_c/repeated_field.h +6 -6
- data/ext/google/protobuf_c/ruby-upb.c +11760 -6644
- data/ext/google/protobuf_c/ruby-upb.h +10765 -3396
- data/ext/google/protobuf_c/third_party/utf8_range/LICENSE +22 -0
- data/ext/google/protobuf_c/third_party/utf8_range/naive.c +92 -0
- data/ext/google/protobuf_c/third_party/utf8_range/range2-neon.c +157 -0
- data/ext/google/protobuf_c/third_party/utf8_range/range2-sse.c +170 -0
- data/ext/google/protobuf_c/third_party/utf8_range/utf8_range.h +21 -0
- data/ext/google/protobuf_c/wrap_memcpy.c +4 -3
- data/lib/google/protobuf/any_pb.rb +24 -5
- data/lib/google/protobuf/api_pb.rb +27 -23
- data/lib/google/protobuf/descriptor_dsl.rb +465 -0
- data/lib/google/protobuf/descriptor_pb.rb +75 -0
- data/lib/google/protobuf/duration_pb.rb +24 -5
- data/lib/google/protobuf/empty_pb.rb +24 -3
- data/lib/google/protobuf/field_mask_pb.rb +24 -4
- data/lib/google/protobuf/message_exts.rb +7 -2
- data/lib/google/protobuf/plugin_pb.rb +47 -0
- data/lib/google/protobuf/repeated_field.rb +15 -2
- data/lib/google/protobuf/source_context_pb.rb +24 -4
- data/lib/google/protobuf/struct_pb.rb +24 -20
- data/lib/google/protobuf/timestamp_pb.rb +24 -5
- data/lib/google/protobuf/type_pb.rb +27 -68
- data/lib/google/protobuf/well_known_types.rb +12 -2
- data/lib/google/protobuf/wrappers_pb.rb +24 -28
- data/lib/google/protobuf.rb +5 -73
- metadata +17 -36
- data/ext/google/protobuf_c/third_party/wyhash/wyhash.h +0 -145
- data/tests/basic.rb +0 -611
- data/tests/generated_code_test.rb +0 -23
- data/tests/stress.rb +0 -38
metadata
CHANGED
@@ -1,35 +1,29 @@
|
|
1
1
|
--- !ruby/object:Gem::Specification
|
2
2
|
name: google-protobuf
|
3
3
|
version: !ruby/object:Gem::Version
|
4
|
-
version: 3.
|
4
|
+
version: 3.23.4
|
5
5
|
platform: ruby
|
6
6
|
authors:
|
7
7
|
- Protobuf Authors
|
8
8
|
autorequire:
|
9
9
|
bindir: bin
|
10
10
|
cert_chain: []
|
11
|
-
date:
|
11
|
+
date: 2023-07-05 00:00:00.000000000 Z
|
12
12
|
dependencies:
|
13
13
|
- !ruby/object:Gem::Dependency
|
14
14
|
name: rake-compiler-dock
|
15
15
|
requirement: !ruby/object:Gem::Requirement
|
16
16
|
requirements:
|
17
|
-
- -
|
18
|
-
- !ruby/object:Gem::Version
|
19
|
-
version: 1.1.0
|
20
|
-
- - "<"
|
17
|
+
- - '='
|
21
18
|
- !ruby/object:Gem::Version
|
22
|
-
version:
|
19
|
+
version: 1.2.1
|
23
20
|
type: :development
|
24
21
|
prerelease: false
|
25
22
|
version_requirements: !ruby/object:Gem::Requirement
|
26
23
|
requirements:
|
27
|
-
- -
|
24
|
+
- - '='
|
28
25
|
- !ruby/object:Gem::Version
|
29
|
-
version: 1.1
|
30
|
-
- - "<"
|
31
|
-
- !ruby/object:Gem::Version
|
32
|
-
version: '2.0'
|
26
|
+
version: 1.2.1
|
33
27
|
- !ruby/object:Gem::Dependency
|
34
28
|
name: rake-compiler
|
35
29
|
requirement: !ruby/object:Gem::Requirement
|
@@ -64,20 +58,6 @@ dependencies:
|
|
64
58
|
- - ">="
|
65
59
|
- !ruby/object:Gem::Version
|
66
60
|
version: 3.0.9
|
67
|
-
- !ruby/object:Gem::Dependency
|
68
|
-
name: rubygems-tasks
|
69
|
-
requirement: !ruby/object:Gem::Requirement
|
70
|
-
requirements:
|
71
|
-
- - "~>"
|
72
|
-
- !ruby/object:Gem::Version
|
73
|
-
version: 0.2.4
|
74
|
-
type: :development
|
75
|
-
prerelease: false
|
76
|
-
version_requirements: !ruby/object:Gem::Requirement
|
77
|
-
requirements:
|
78
|
-
- - "~>"
|
79
|
-
- !ruby/object:Gem::Version
|
80
|
-
version: 0.2.4
|
81
61
|
description: Protocol Buffers are Google's data interchange format.
|
82
62
|
email: protobuf@googlegroups.com
|
83
63
|
executables: []
|
@@ -100,15 +80,22 @@ files:
|
|
100
80
|
- ext/google/protobuf_c/repeated_field.h
|
101
81
|
- ext/google/protobuf_c/ruby-upb.c
|
102
82
|
- ext/google/protobuf_c/ruby-upb.h
|
103
|
-
- ext/google/protobuf_c/third_party/
|
83
|
+
- ext/google/protobuf_c/third_party/utf8_range/LICENSE
|
84
|
+
- ext/google/protobuf_c/third_party/utf8_range/naive.c
|
85
|
+
- ext/google/protobuf_c/third_party/utf8_range/range2-neon.c
|
86
|
+
- ext/google/protobuf_c/third_party/utf8_range/range2-sse.c
|
87
|
+
- ext/google/protobuf_c/third_party/utf8_range/utf8_range.h
|
104
88
|
- ext/google/protobuf_c/wrap_memcpy.c
|
105
89
|
- lib/google/protobuf.rb
|
106
90
|
- lib/google/protobuf/any_pb.rb
|
107
91
|
- lib/google/protobuf/api_pb.rb
|
92
|
+
- lib/google/protobuf/descriptor_dsl.rb
|
93
|
+
- lib/google/protobuf/descriptor_pb.rb
|
108
94
|
- lib/google/protobuf/duration_pb.rb
|
109
95
|
- lib/google/protobuf/empty_pb.rb
|
110
96
|
- lib/google/protobuf/field_mask_pb.rb
|
111
97
|
- lib/google/protobuf/message_exts.rb
|
98
|
+
- lib/google/protobuf/plugin_pb.rb
|
112
99
|
- lib/google/protobuf/repeated_field.rb
|
113
100
|
- lib/google/protobuf/source_context_pb.rb
|
114
101
|
- lib/google/protobuf/struct_pb.rb
|
@@ -116,14 +103,11 @@ files:
|
|
116
103
|
- lib/google/protobuf/type_pb.rb
|
117
104
|
- lib/google/protobuf/well_known_types.rb
|
118
105
|
- lib/google/protobuf/wrappers_pb.rb
|
119
|
-
- tests/basic.rb
|
120
|
-
- tests/generated_code_test.rb
|
121
|
-
- tests/stress.rb
|
122
106
|
homepage: https://developers.google.com/protocol-buffers
|
123
107
|
licenses:
|
124
108
|
- BSD-3-Clause
|
125
109
|
metadata:
|
126
|
-
source_code_uri: https://github.com/protocolbuffers/protobuf/tree/v3.
|
110
|
+
source_code_uri: https://github.com/protocolbuffers/protobuf/tree/v3.23.4/ruby
|
127
111
|
post_install_message:
|
128
112
|
rdoc_options: []
|
129
113
|
require_paths:
|
@@ -139,11 +123,8 @@ required_rubygems_version: !ruby/object:Gem::Requirement
|
|
139
123
|
- !ruby/object:Gem::Version
|
140
124
|
version: '0'
|
141
125
|
requirements: []
|
142
|
-
rubygems_version: 3.
|
126
|
+
rubygems_version: 3.0.8
|
143
127
|
signing_key:
|
144
128
|
specification_version: 4
|
145
129
|
summary: Protocol Buffers
|
146
|
-
test_files:
|
147
|
-
- tests/basic.rb
|
148
|
-
- tests/stress.rb
|
149
|
-
- tests/generated_code_test.rb
|
130
|
+
test_files: []
|
@@ -1,145 +0,0 @@
|
|
1
|
-
/* Copyright 2020 王一 Wang Yi <godspeed_china@yeah.net>
|
2
|
-
This is free and unencumbered software released into the public domain. http://unlicense.org/
|
3
|
-
See github.com/wangyi-fudan/wyhash/ LICENSE
|
4
|
-
*/
|
5
|
-
#ifndef wyhash_final_version
|
6
|
-
#define wyhash_final_version
|
7
|
-
//defines that change behavior
|
8
|
-
#ifndef WYHASH_CONDOM
|
9
|
-
#define WYHASH_CONDOM 1 //0: read 8 bytes before and after boundaries, dangerous but fastest. 1: normal valid behavior 2: extra protection against entropy loss (probability=2^-63), aka. "blind multiplication"
|
10
|
-
#endif
|
11
|
-
#define WYHASH_32BIT_MUM 0 //faster on 32 bit system
|
12
|
-
//includes
|
13
|
-
#include <stdint.h>
|
14
|
-
#include <string.h>
|
15
|
-
#if defined(_MSC_VER) && defined(_M_X64)
|
16
|
-
#include <intrin.h>
|
17
|
-
#pragma intrinsic(_umul128)
|
18
|
-
#endif
|
19
|
-
#if defined(__GNUC__) || defined(__INTEL_COMPILER) || defined(__clang__)
|
20
|
-
#define _likely_(x) __builtin_expect(x,1)
|
21
|
-
#define _unlikely_(x) __builtin_expect(x,0)
|
22
|
-
#else
|
23
|
-
#define _likely_(x) (x)
|
24
|
-
#define _unlikely_(x) (x)
|
25
|
-
#endif
|
26
|
-
//mum function
|
27
|
-
static inline uint64_t _wyrot(uint64_t x) { return (x>>32)|(x<<32); }
|
28
|
-
static inline void _wymum(uint64_t *A, uint64_t *B){
|
29
|
-
#if(WYHASH_32BIT_MUM)
|
30
|
-
uint64_t hh=(*A>>32)*(*B>>32), hl=(*A>>32)*(unsigned)*B, lh=(unsigned)*A*(*B>>32), ll=(uint64_t)(unsigned)*A*(unsigned)*B;
|
31
|
-
#if(WYHASH_CONDOM>1)
|
32
|
-
*A^=_wyrot(hl)^hh; *B^=_wyrot(lh)^ll;
|
33
|
-
#else
|
34
|
-
*A=_wyrot(hl)^hh; *B=_wyrot(lh)^ll;
|
35
|
-
#endif
|
36
|
-
#elif defined(__SIZEOF_INT128__)
|
37
|
-
__uint128_t r=*A; r*=*B;
|
38
|
-
#if(WYHASH_CONDOM>1)
|
39
|
-
*A^=(uint64_t)r; *B^=(uint64_t)(r>>64);
|
40
|
-
#else
|
41
|
-
*A=(uint64_t)r; *B=(uint64_t)(r>>64);
|
42
|
-
#endif
|
43
|
-
#elif defined(_MSC_VER) && defined(_M_X64)
|
44
|
-
#if(WYHASH_CONDOM>1)
|
45
|
-
uint64_t a, b;
|
46
|
-
a=_umul128(*A,*B,&b);
|
47
|
-
*A^=a; *B^=b;
|
48
|
-
#else
|
49
|
-
*A=_umul128(*A,*B,B);
|
50
|
-
#endif
|
51
|
-
#else
|
52
|
-
uint64_t ha=*A>>32, hb=*B>>32, la=(uint32_t)*A, lb=(uint32_t)*B, hi, lo;
|
53
|
-
uint64_t rh=ha*hb, rm0=ha*lb, rm1=hb*la, rl=la*lb, t=rl+(rm0<<32), c=t<rl;
|
54
|
-
lo=t+(rm1<<32); c+=lo<t; hi=rh+(rm0>>32)+(rm1>>32)+c;
|
55
|
-
#if(WYHASH_CONDOM>1)
|
56
|
-
*A^=lo; *B^=hi;
|
57
|
-
#else
|
58
|
-
*A=lo; *B=hi;
|
59
|
-
#endif
|
60
|
-
#endif
|
61
|
-
}
|
62
|
-
static inline uint64_t _wymix(uint64_t A, uint64_t B){ _wymum(&A,&B); return A^B; }
|
63
|
-
//read functions
|
64
|
-
#ifndef WYHASH_LITTLE_ENDIAN
|
65
|
-
#if defined(_WIN32) || defined(__LITTLE_ENDIAN__) || (defined(__BYTE_ORDER__) && __BYTE_ORDER__ == __ORDER_LITTLE_ENDIAN__)
|
66
|
-
#define WYHASH_LITTLE_ENDIAN 1
|
67
|
-
#elif defined(__BIG_ENDIAN__) || (defined(__BYTE_ORDER__) && __BYTE_ORDER__ == __ORDER_BIG_ENDIAN__)
|
68
|
-
#define WYHASH_LITTLE_ENDIAN 0
|
69
|
-
#endif
|
70
|
-
#endif
|
71
|
-
#if (WYHASH_LITTLE_ENDIAN)
|
72
|
-
static inline uint64_t _wyr8(const uint8_t *p) { uint64_t v; memcpy(&v, p, 8); return v;}
|
73
|
-
static inline uint64_t _wyr4(const uint8_t *p) { unsigned v; memcpy(&v, p, 4); return v;}
|
74
|
-
#elif defined(__GNUC__) || defined(__INTEL_COMPILER) || defined(__clang__)
|
75
|
-
static inline uint64_t _wyr8(const uint8_t *p) { uint64_t v; memcpy(&v, p, 8); return __builtin_bswap64(v);}
|
76
|
-
static inline uint64_t _wyr4(const uint8_t *p) { unsigned v; memcpy(&v, p, 4); return __builtin_bswap32(v);}
|
77
|
-
#elif defined(_MSC_VER)
|
78
|
-
static inline uint64_t _wyr8(const uint8_t *p) { uint64_t v; memcpy(&v, p, 8); return _byteswap_uint64(v);}
|
79
|
-
static inline uint64_t _wyr4(const uint8_t *p) { unsigned v; memcpy(&v, p, 4); return _byteswap_ulong(v);}
|
80
|
-
#endif
|
81
|
-
static inline uint64_t _wyr3(const uint8_t *p, unsigned k) { return (((uint64_t)p[0])<<16)|(((uint64_t)p[k>>1])<<8)|p[k-1];}
|
82
|
-
//wyhash function
|
83
|
-
static inline uint64_t _wyfinish16(const uint8_t *p, uint64_t len, uint64_t seed, const uint64_t *secret, uint64_t i){
|
84
|
-
#if(WYHASH_CONDOM>0)
|
85
|
-
uint64_t a, b;
|
86
|
-
if(_likely_(i<=8)){
|
87
|
-
if(_likely_(i>=4)){ a=_wyr4(p); b=_wyr4(p+i-4); }
|
88
|
-
else if (_likely_(i)){ a=_wyr3(p,i); b=0; }
|
89
|
-
else a=b=0;
|
90
|
-
}
|
91
|
-
else{ a=_wyr8(p); b=_wyr8(p+i-8); }
|
92
|
-
return _wymix(secret[1]^len,_wymix(a^secret[1], b^seed));
|
93
|
-
#else
|
94
|
-
#define oneshot_shift ((i<8)*((8-i)<<3))
|
95
|
-
return _wymix(secret[1]^len,_wymix((_wyr8(p)<<oneshot_shift)^secret[1],(_wyr8(p+i-8)>>oneshot_shift)^seed));
|
96
|
-
#endif
|
97
|
-
}
|
98
|
-
|
99
|
-
static inline uint64_t _wyfinish(const uint8_t *p, uint64_t len, uint64_t seed, const uint64_t *secret, uint64_t i){
|
100
|
-
if(_likely_(i<=16)) return _wyfinish16(p,len,seed,secret,i);
|
101
|
-
return _wyfinish(p+16,len,_wymix(_wyr8(p)^secret[1],_wyr8(p+8)^seed),secret,i-16);
|
102
|
-
}
|
103
|
-
|
104
|
-
static inline uint64_t wyhash(const void *key, uint64_t len, uint64_t seed, const uint64_t *secret){
|
105
|
-
const uint8_t *p=(const uint8_t *)key;
|
106
|
-
uint64_t i=len; seed^=*secret;
|
107
|
-
if(_unlikely_(i>64)){
|
108
|
-
uint64_t see1=seed;
|
109
|
-
do{
|
110
|
-
seed=_wymix(_wyr8(p)^secret[1],_wyr8(p+8)^seed)^_wymix(_wyr8(p+16)^secret[2],_wyr8(p+24)^seed);
|
111
|
-
see1=_wymix(_wyr8(p+32)^secret[3],_wyr8(p+40)^see1)^_wymix(_wyr8(p+48)^secret[4],_wyr8(p+56)^see1);
|
112
|
-
p+=64; i-=64;
|
113
|
-
}while(i>64);
|
114
|
-
seed^=see1;
|
115
|
-
}
|
116
|
-
return _wyfinish(p,len,seed,secret,i);
|
117
|
-
}
|
118
|
-
//utility functions
|
119
|
-
static const uint64_t _wyp[5] = {0xa0761d6478bd642full, 0xe7037ed1a0b428dbull, 0x8ebc6af09c88c6e3ull, 0x589965cc75374cc3ull, 0x1d8e4e27c47d124full};
|
120
|
-
static inline uint64_t wyhash64(uint64_t A, uint64_t B){ A^=_wyp[0]; B^=_wyp[1]; _wymum(&A,&B); return _wymix(A^_wyp[0],B^_wyp[1]);}
|
121
|
-
static inline uint64_t wyrand(uint64_t *seed){ *seed+=_wyp[0]; return _wymix(*seed,*seed^_wyp[1]);}
|
122
|
-
static inline double wy2u01(uint64_t r){ const double _wynorm=1.0/(1ull<<52); return (r>>12)*_wynorm;}
|
123
|
-
static inline double wy2gau(uint64_t r){ const double _wynorm=1.0/(1ull<<20); return ((r&0x1fffff)+((r>>21)&0x1fffff)+((r>>42)&0x1fffff))*_wynorm-3.0;}
|
124
|
-
static inline uint64_t wy2u0k(uint64_t r, uint64_t k){ _wymum(&r,&k); return k; }
|
125
|
-
|
126
|
-
static inline void make_secret(uint64_t seed, uint64_t *secret){
|
127
|
-
uint8_t c[] = {15, 23, 27, 29, 30, 39, 43, 45, 46, 51, 53, 54, 57, 58, 60, 71, 75, 77, 78, 83, 85, 86, 89, 90, 92, 99, 101, 102, 105, 106, 108, 113, 114, 116, 120, 135, 139, 141, 142, 147, 149, 150, 153, 154, 156, 163, 165, 166, 169, 170, 172, 177, 178, 180, 184, 195, 197, 198, 201, 202, 204, 209, 210, 212, 216, 225, 226, 228, 232, 240 };
|
128
|
-
for(size_t i=0;i<5;i++){
|
129
|
-
uint8_t ok;
|
130
|
-
do{
|
131
|
-
ok=1; secret[i]=0;
|
132
|
-
for(size_t j=0;j<64;j+=8) secret[i]|=((uint64_t)c[wyrand(&seed)%sizeof(c)])<<j;
|
133
|
-
if(secret[i]%2==0){ ok=0; continue; }
|
134
|
-
for(size_t j=0;j<i;j++)
|
135
|
-
#if defined(__GNUC__) || defined(__INTEL_COMPILER) || defined(__clang__)
|
136
|
-
if(__builtin_popcountll(secret[j]^secret[i])!=32){ ok=0; break; }
|
137
|
-
#elif defined(_MSC_VER) && defined(_M_X64)
|
138
|
-
if(_mm_popcnt_u64(secret[j]^secret[i])!=32){ ok=0; break; }
|
139
|
-
#endif
|
140
|
-
if(!ok)continue;
|
141
|
-
for(uint64_t j=3;j<0x100000000ull;j+=2) if(secret[i]%j==0){ ok=0; break; }
|
142
|
-
}while(!ok);
|
143
|
-
}
|
144
|
-
}
|
145
|
-
#endif
|