google-protobuf 3.17.3 → 3.22.1-arm64-darwin
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 +217 -1521
- 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 +438 -341
- data/ext/google/protobuf_c/message.h +22 -19
- data/ext/google/protobuf_c/protobuf.c +68 -58
- 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 +11782 -6714
- data/ext/google/protobuf_c/ruby-upb.h +9668 -3406
- 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/2.6/protobuf_c.bundle +0 -0
- data/lib/google/2.7/protobuf_c.bundle +0 -0
- data/lib/google/3.0/protobuf_c.bundle +0 -0
- data/lib/google/3.1/protobuf_c.bundle +0 -0
- data/lib/google/3.2/protobuf_c.bundle +0 -0
- data/lib/google/protobuf/any_pb.rb +0 -0
- data/lib/google/protobuf/api_pb.rb +1 -0
- data/lib/google/protobuf/descriptor_dsl.rb +465 -0
- data/lib/google/protobuf/descriptor_pb.rb +298 -0
- data/lib/google/protobuf/duration_pb.rb +0 -0
- data/lib/google/protobuf/empty_pb.rb +0 -0
- data/lib/google/protobuf/field_mask_pb.rb +0 -0
- data/lib/google/protobuf/message_exts.rb +7 -2
- data/lib/google/protobuf/plugin_pb.rb +50 -0
- data/lib/google/protobuf/repeated_field.rb +15 -2
- data/lib/google/protobuf/source_context_pb.rb +0 -0
- data/lib/google/protobuf/struct_pb.rb +0 -0
- data/lib/google/protobuf/timestamp_pb.rb +0 -0
- data/lib/google/protobuf/type_pb.rb +1 -0
- data/lib/google/protobuf/well_known_types.rb +12 -2
- data/lib/google/protobuf/wrappers_pb.rb +0 -0
- data/lib/google/protobuf.rb +5 -73
- metadata +28 -40
- 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.
|
5
|
-
platform:
|
4
|
+
version: 3.22.1
|
5
|
+
platform: arm64-darwin
|
6
6
|
authors:
|
7
7
|
- Protobuf Authors
|
8
8
|
autorequire:
|
9
9
|
bindir: bin
|
10
10
|
cert_chain: []
|
11
|
-
date:
|
11
|
+
date: 2023-03-07 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
|
-
- -
|
28
|
-
- !ruby/object:Gem::Version
|
29
|
-
version: 1.1.0
|
30
|
-
- - "<"
|
24
|
+
- - '='
|
31
25
|
- !ruby/object:Gem::Version
|
32
|
-
version:
|
26
|
+
version: 1.2.1
|
33
27
|
- !ruby/object:Gem::Dependency
|
34
28
|
name: rake-compiler
|
35
29
|
requirement: !ruby/object:Gem::Requirement
|
@@ -64,25 +58,10 @@ 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: []
|
84
|
-
extensions:
|
85
|
-
- ext/google/protobuf_c/extconf.rb
|
64
|
+
extensions: []
|
86
65
|
extra_rdoc_files: []
|
87
66
|
files:
|
88
67
|
- ext/google/protobuf_c/convert.c
|
@@ -100,15 +79,27 @@ files:
|
|
100
79
|
- ext/google/protobuf_c/repeated_field.h
|
101
80
|
- ext/google/protobuf_c/ruby-upb.c
|
102
81
|
- ext/google/protobuf_c/ruby-upb.h
|
103
|
-
- ext/google/protobuf_c/third_party/
|
82
|
+
- ext/google/protobuf_c/third_party/utf8_range/LICENSE
|
83
|
+
- ext/google/protobuf_c/third_party/utf8_range/naive.c
|
84
|
+
- ext/google/protobuf_c/third_party/utf8_range/range2-neon.c
|
85
|
+
- ext/google/protobuf_c/third_party/utf8_range/range2-sse.c
|
86
|
+
- ext/google/protobuf_c/third_party/utf8_range/utf8_range.h
|
104
87
|
- ext/google/protobuf_c/wrap_memcpy.c
|
88
|
+
- lib/google/2.6/protobuf_c.bundle
|
89
|
+
- lib/google/2.7/protobuf_c.bundle
|
90
|
+
- lib/google/3.0/protobuf_c.bundle
|
91
|
+
- lib/google/3.1/protobuf_c.bundle
|
92
|
+
- lib/google/3.2/protobuf_c.bundle
|
105
93
|
- lib/google/protobuf.rb
|
106
94
|
- lib/google/protobuf/any_pb.rb
|
107
95
|
- lib/google/protobuf/api_pb.rb
|
96
|
+
- lib/google/protobuf/descriptor_dsl.rb
|
97
|
+
- lib/google/protobuf/descriptor_pb.rb
|
108
98
|
- lib/google/protobuf/duration_pb.rb
|
109
99
|
- lib/google/protobuf/empty_pb.rb
|
110
100
|
- lib/google/protobuf/field_mask_pb.rb
|
111
101
|
- lib/google/protobuf/message_exts.rb
|
102
|
+
- lib/google/protobuf/plugin_pb.rb
|
112
103
|
- lib/google/protobuf/repeated_field.rb
|
113
104
|
- lib/google/protobuf/source_context_pb.rb
|
114
105
|
- lib/google/protobuf/struct_pb.rb
|
@@ -116,14 +107,11 @@ files:
|
|
116
107
|
- lib/google/protobuf/type_pb.rb
|
117
108
|
- lib/google/protobuf/well_known_types.rb
|
118
109
|
- lib/google/protobuf/wrappers_pb.rb
|
119
|
-
- tests/basic.rb
|
120
|
-
- tests/generated_code_test.rb
|
121
|
-
- tests/stress.rb
|
122
110
|
homepage: https://developers.google.com/protocol-buffers
|
123
111
|
licenses:
|
124
112
|
- BSD-3-Clause
|
125
113
|
metadata:
|
126
|
-
source_code_uri: https://github.com/protocolbuffers/protobuf/tree/v3.
|
114
|
+
source_code_uri: https://github.com/protocolbuffers/protobuf/tree/v3.22.1/ruby
|
127
115
|
post_install_message:
|
128
116
|
rdoc_options: []
|
129
117
|
require_paths:
|
@@ -132,18 +120,18 @@ required_ruby_version: !ruby/object:Gem::Requirement
|
|
132
120
|
requirements:
|
133
121
|
- - ">="
|
134
122
|
- !ruby/object:Gem::Version
|
135
|
-
version: '2.
|
123
|
+
version: '2.6'
|
124
|
+
- - "<"
|
125
|
+
- !ruby/object:Gem::Version
|
126
|
+
version: 3.3.dev
|
136
127
|
required_rubygems_version: !ruby/object:Gem::Requirement
|
137
128
|
requirements:
|
138
129
|
- - ">="
|
139
130
|
- !ruby/object:Gem::Version
|
140
131
|
version: '0'
|
141
132
|
requirements: []
|
142
|
-
rubygems_version: 3.
|
133
|
+
rubygems_version: 3.3.26
|
143
134
|
signing_key:
|
144
135
|
specification_version: 4
|
145
136
|
summary: Protocol Buffers
|
146
|
-
test_files:
|
147
|
-
- tests/basic.rb
|
148
|
-
- tests/stress.rb
|
149
|
-
- tests/generated_code_test.rb
|
137
|
+
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
|