protobuf 2.7.2-java → 2.7.3-java
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.
- data/README.md +5 -5
- data/lib/protobuf/cli.rb +13 -4
- data/lib/protobuf/rpc/servers/evented_runner.rb +7 -2
- data/lib/protobuf/rpc/servers/socket_runner.rb +6 -2
- data/lib/protobuf/rpc/servers/zmq/broker.rb +2 -3
- data/lib/protobuf/rpc/servers/zmq/server.rb +20 -8
- data/lib/protobuf/rpc/servers/zmq/worker.rb +1 -1
- data/lib/protobuf/rpc/servers/zmq_runner.rb +14 -4
- data/lib/protobuf/version.rb +1 -1
- data/spec/functional/zmq_server_spec.rb +7 -1
- data/spec/lib/protobuf/cli_spec.rb +46 -0
- data/spec/lib/protobuf/rpc/servers/zmq/broker_spec.rb +1 -1
- data/spec/support/server.rb +1 -0
- metadata +156 -145
data/README.md
CHANGED
@@ -92,11 +92,11 @@ end
|
|
92
92
|
```
|
93
93
|
|
94
94
|
___Note:__ The generator will pre-define all the classes empty and then
|
95
|
-
re-open to apply the defined fields. This is an
|
95
|
+
re-open to apply the defined fields. This is an optimization to prevent
|
96
96
|
recursive field errors._
|
97
97
|
|
98
|
-
The generated class is now just a plain old ruby object
|
99
|
-
can use it however you wish.
|
98
|
+
The generated class is now just a plain old ruby object.
|
99
|
+
You can use it however you wish.
|
100
100
|
|
101
101
|
```ruby
|
102
102
|
require 'lib/foo/user.pb'
|
@@ -340,7 +340,7 @@ that the phone company disconnected their house. Sad and pathetic.
|
|
340
340
|
So hook up the phone lines!
|
341
341
|
|
342
342
|
```
|
343
|
-
$ rpc_server -o myserver.com -p
|
343
|
+
$ rpc_server -o myserver.com -p 9399 -l ./log/protobuf.log ./config/environment.rb
|
344
344
|
```
|
345
345
|
|
346
346
|
The previous call will start a Socket server running on the given
|
@@ -364,7 +364,7 @@ result in shutting the server down gracefully.
|
|
364
364
|
|
365
365
|
```
|
366
366
|
$ ps aux | grep rpc_server
|
367
|
-
1234 ... rpc_server myservice.com:
|
367
|
+
1234 ... rpc_server myservice.com:9399
|
368
368
|
|
369
369
|
$ kill -QUIT 1234
|
370
370
|
rpc_server shutdown
|
data/lib/protobuf/cli.rb
CHANGED
@@ -32,6 +32,8 @@ module Protobuf
|
|
32
32
|
option :debug, :type => :boolean, :default => false, :aliases => %w(-d), :desc => 'Debug Mode. Override log level to DEBUG.'
|
33
33
|
option :gc_pause_request, :type => :boolean, :default => false, :desc => 'Enable/Disable GC pause during request.'
|
34
34
|
option :print_deprecation_warnings, :type => :boolean, :default => nil, :desc => 'Cause use of deprecated fields to be printed or ignored.'
|
35
|
+
option :workers_only, :type => :boolean, :default => false, :desc => "Starts process with only workers (no broker/frontend is started) only relevant for Zmq Server"
|
36
|
+
option :worker_port, :type => :numeric, :default => nil, :desc => "Port for 'backend' where workers connect (defaults to port + 1)"
|
35
37
|
|
36
38
|
def start(app_file)
|
37
39
|
debug_say 'Configuring the rpc_server process'
|
@@ -47,7 +49,6 @@ module Protobuf
|
|
47
49
|
run_if_no_abort { require_application!(app_file) }
|
48
50
|
run_if_no_abort { configure_process_name(app_file) }
|
49
51
|
run_if_no_abort { start_server! }
|
50
|
-
|
51
52
|
rescue => e
|
52
53
|
say_and_exit!('ERROR: RPC Server failed to start.', e)
|
53
54
|
end
|
@@ -170,11 +171,15 @@ module Protobuf
|
|
170
171
|
end
|
171
172
|
|
172
173
|
def runner_options
|
173
|
-
{
|
174
|
+
{
|
175
|
+
:host => options.host,
|
174
176
|
:port => options.port,
|
175
177
|
:backlog => options.backlog,
|
176
178
|
:threshold => options.threshold,
|
177
|
-
:threads => options.threads
|
179
|
+
:threads => options.threads,
|
180
|
+
:worker_port => options.worker_port || (options.port + 1),
|
181
|
+
:workers_only => !!ENV['PB_WORKERS_ONLY'] || options.workers_only
|
182
|
+
}
|
178
183
|
end
|
179
184
|
|
180
185
|
def say_and_exit!(message, exception = nil)
|
@@ -209,9 +214,13 @@ module Protobuf
|
|
209
214
|
|
210
215
|
# Start the runner and log the relevant options.
|
211
216
|
def start_server!
|
217
|
+
@runner.register_signals
|
218
|
+
|
212
219
|
debug_say 'Invoking server start'
|
213
220
|
@runner.run(runner_options) do
|
214
|
-
Protobuf::Logger.info {
|
221
|
+
::Protobuf::Logger.info {
|
222
|
+
"pid #{::Process.pid} -- #{@mode} RPC Server listening at #{options.host}:#{options.port}"
|
223
|
+
}
|
215
224
|
end
|
216
225
|
end
|
217
226
|
|
@@ -2,8 +2,8 @@ module Protobuf
|
|
2
2
|
module Rpc
|
3
3
|
class EventedRunner
|
4
4
|
|
5
|
-
def self.
|
6
|
-
|
5
|
+
def self.register_signals
|
6
|
+
# Noop
|
7
7
|
end
|
8
8
|
|
9
9
|
def self.run(options)
|
@@ -16,6 +16,11 @@ module Protobuf
|
|
16
16
|
yield if block_given?
|
17
17
|
::EM.reactor_running? ? ::EM.reactor_thread.join : ::EM.run
|
18
18
|
end
|
19
|
+
|
20
|
+
def self.stop
|
21
|
+
::EventMachine.stop_event_loop if ::EventMachine.reactor_running?
|
22
|
+
end
|
23
|
+
|
19
24
|
end
|
20
25
|
end
|
21
26
|
end
|
@@ -2,8 +2,8 @@ module Protobuf
|
|
2
2
|
module Rpc
|
3
3
|
class SocketRunner
|
4
4
|
|
5
|
-
def self.
|
6
|
-
|
5
|
+
def self.register_signals
|
6
|
+
# noop
|
7
7
|
end
|
8
8
|
|
9
9
|
def self.run(server)
|
@@ -22,6 +22,10 @@ module Protobuf
|
|
22
22
|
::Protobuf::Rpc::Socket::Server.run(server_config)
|
23
23
|
end
|
24
24
|
|
25
|
+
def self.stop
|
26
|
+
::Protobuf::Rpc::Socket::Server.stop
|
27
|
+
end
|
28
|
+
|
25
29
|
end
|
26
30
|
end
|
27
31
|
end
|
@@ -85,9 +85,8 @@ module Protobuf
|
|
85
85
|
end
|
86
86
|
|
87
87
|
def setup_backend(options = {})
|
88
|
-
|
89
|
-
|
90
|
-
port = dealer_options[:port]
|
88
|
+
host = options[:host]
|
89
|
+
port = options[:worker_port]
|
91
90
|
|
92
91
|
zmq_backend = context.socket(::ZMQ::ROUTER)
|
93
92
|
zmq_error_check(zmq_backend.bind(bind_address(host, port)))
|
@@ -12,11 +12,14 @@ module Protobuf
|
|
12
12
|
# Class Methods
|
13
13
|
#
|
14
14
|
def self.run(options = {})
|
15
|
-
|
16
|
-
|
17
|
-
|
15
|
+
@options = options
|
16
|
+
|
17
|
+
unless options[:workers_only]
|
18
|
+
log_debug { sign_message("initializing broker") }
|
19
|
+
@broker = ::Protobuf::Rpc::Zmq::Broker.new(options)
|
20
|
+
end
|
18
21
|
|
19
|
-
|
22
|
+
local_worker_threads = options[:threads]
|
20
23
|
log_debug { sign_message("starting server workers") }
|
21
24
|
|
22
25
|
local_worker_threads.times do
|
@@ -26,7 +29,12 @@ module Protobuf
|
|
26
29
|
@running = true
|
27
30
|
log_debug { sign_message("server started") }
|
28
31
|
while self.running? do
|
29
|
-
|
32
|
+
if options[:workers_only]
|
33
|
+
sleep 5
|
34
|
+
Thread.pass
|
35
|
+
else
|
36
|
+
@broker.poll
|
37
|
+
end
|
30
38
|
end
|
31
39
|
ensure
|
32
40
|
@broker.teardown if @broker
|
@@ -37,11 +45,11 @@ module Protobuf
|
|
37
45
|
end
|
38
46
|
|
39
47
|
def self.start_worker
|
40
|
-
@threads << Thread.new(@
|
48
|
+
@threads << Thread.new(@options) { |options|
|
41
49
|
begin
|
42
|
-
::Protobuf::Rpc::Zmq::Worker.new(
|
50
|
+
::Protobuf::Rpc::Zmq::Worker.new(options).run
|
43
51
|
rescue => e
|
44
|
-
message = "Worker Failed, spawning new worker: #{e.inspect}\n #{e.backtrace.join(
|
52
|
+
message = "Worker Failed, spawning new worker: #{e.inspect}\n #{e.backtrace.join($/)}"
|
45
53
|
$stderr.puts message
|
46
54
|
log_error { message }
|
47
55
|
|
@@ -58,6 +66,10 @@ module Protobuf
|
|
58
66
|
end
|
59
67
|
end
|
60
68
|
|
69
|
+
def self.threads
|
70
|
+
@threads
|
71
|
+
end
|
72
|
+
|
61
73
|
@threads ||= []
|
62
74
|
end
|
63
75
|
end
|
@@ -1,9 +1,14 @@
|
|
1
1
|
module Protobuf
|
2
2
|
module Rpc
|
3
3
|
class ZmqRunner
|
4
|
+
include ::Protobuf::Logger::LogMethods
|
4
5
|
|
5
|
-
def self.
|
6
|
-
|
6
|
+
def self.register_signals
|
7
|
+
trap(:TTIN) do
|
8
|
+
log_info { "TTIN received: Starting new worker" }
|
9
|
+
::Protobuf::Rpc::Zmq::Server.start_worker
|
10
|
+
log_info { "Worker count : #{::Protobuf::Rpc::Zmq::Server.threads.size}" }
|
11
|
+
end
|
7
12
|
end
|
8
13
|
|
9
14
|
def self.run(server)
|
@@ -17,9 +22,14 @@ module Protobuf
|
|
17
22
|
end
|
18
23
|
|
19
24
|
yield if block_given?
|
20
|
-
|
25
|
+
|
26
|
+
::Protobuf::Rpc::Zmq::Server.run(server_config)
|
21
27
|
end
|
22
|
-
end
|
23
28
|
|
29
|
+
def self.stop
|
30
|
+
::Protobuf::Rpc::Zmq::Server.stop
|
31
|
+
end
|
32
|
+
|
33
|
+
end
|
24
34
|
end
|
25
35
|
end
|
data/lib/protobuf/version.rb
CHANGED
@@ -5,7 +5,13 @@ describe 'Functional ZMQ Client' do
|
|
5
5
|
before(:all) do
|
6
6
|
load "protobuf/zmq.rb"
|
7
7
|
Thread.abort_on_exception = true
|
8
|
-
server = OpenStruct.new(:host => "127.0.0.1",
|
8
|
+
server = OpenStruct.new(:host => "127.0.0.1",
|
9
|
+
:port => 9399,
|
10
|
+
:worker_port => 9400,
|
11
|
+
:backlog => 100,
|
12
|
+
:threshold => 100,
|
13
|
+
:threads => 5)
|
14
|
+
|
9
15
|
@server_thread = Thread.new(server) { |s| Protobuf::Rpc::ZmqRunner.run(s) }
|
10
16
|
Thread.pass until Protobuf::Rpc::Zmq::Server.running?
|
11
17
|
end
|
@@ -215,6 +215,52 @@ describe ::Protobuf::CLI do
|
|
215
215
|
::Protobuf.connector_type.should == :evented
|
216
216
|
end
|
217
217
|
end
|
218
|
+
|
219
|
+
context 'zmq workers only' do
|
220
|
+
let(:test_args) { [ '--workers_only', '--zmq' ] }
|
221
|
+
let(:runner) { ::Protobuf::Rpc::ZmqRunner }
|
222
|
+
|
223
|
+
before do
|
224
|
+
::Protobuf::Rpc::SocketRunner.should_not_receive(:run)
|
225
|
+
::Protobuf::Rpc::EventedRunner.should_not_receive(:run)
|
226
|
+
end
|
227
|
+
|
228
|
+
it 'is activated by the --workers_only switch' do
|
229
|
+
runner.should_receive(:run) do |options|
|
230
|
+
options[:workers_only].should be_true
|
231
|
+
end
|
232
|
+
|
233
|
+
described_class.start(args)
|
234
|
+
end
|
235
|
+
|
236
|
+
it 'is activated by PB_WORKERS_ONLY=1 ENV variable' do
|
237
|
+
ENV['PB_WORKERS_ONLY'] = "1"
|
238
|
+
runner.should_receive(:run) do |options|
|
239
|
+
options[:workers_only].should be_true
|
240
|
+
end
|
241
|
+
|
242
|
+
described_class.start(args)
|
243
|
+
ENV.delete('PB_WORKERS_ONLY')
|
244
|
+
end
|
245
|
+
end
|
246
|
+
|
247
|
+
context 'zmq worker port' do
|
248
|
+
let(:test_args) { [ '--worker_port=1234', '--zmq' ] }
|
249
|
+
let(:runner) { ::Protobuf::Rpc::ZmqRunner }
|
250
|
+
|
251
|
+
before do
|
252
|
+
::Protobuf::Rpc::SocketRunner.should_not_receive(:run)
|
253
|
+
::Protobuf::Rpc::EventedRunner.should_not_receive(:run)
|
254
|
+
end
|
255
|
+
|
256
|
+
it 'is activated by the --worker_port switch' do
|
257
|
+
runner.should_receive(:run) do |options|
|
258
|
+
options[:worker_port].should eq(1234)
|
259
|
+
end
|
260
|
+
|
261
|
+
described_class.start(args)
|
262
|
+
end
|
263
|
+
end
|
218
264
|
|
219
265
|
context 'zmq' do
|
220
266
|
let(:test_args) { [ '--zmq' ] }
|
data/spec/support/server.rb
CHANGED
metadata
CHANGED
@@ -2,7 +2,7 @@
|
|
2
2
|
name: protobuf
|
3
3
|
version: !ruby/object:Gem::Version
|
4
4
|
prerelease:
|
5
|
-
version: 2.7.
|
5
|
+
version: 2.7.3
|
6
6
|
platform: java
|
7
7
|
authors:
|
8
8
|
- BJ Neilsen
|
@@ -10,149 +10,240 @@ authors:
|
|
10
10
|
autorequire:
|
11
11
|
bindir: bin
|
12
12
|
cert_chain: []
|
13
|
-
date: 2013-
|
13
|
+
date: 2013-03-04 00:00:00.000000000 Z
|
14
14
|
dependencies:
|
15
15
|
- !ruby/object:Gem::Dependency
|
16
16
|
name: activesupport
|
17
|
-
version_requirements:
|
17
|
+
version_requirements: !ruby/object:Gem::Requirement
|
18
18
|
requirements:
|
19
|
-
- -
|
19
|
+
- - ">="
|
20
20
|
- !ruby/object:Gem::Version
|
21
|
-
version:
|
21
|
+
version: !binary |-
|
22
|
+
MA==
|
23
|
+
none: false
|
24
|
+
requirement: !ruby/object:Gem::Requirement
|
25
|
+
requirements:
|
26
|
+
- - ">="
|
27
|
+
- !ruby/object:Gem::Version
|
28
|
+
version: !binary |-
|
29
|
+
MA==
|
22
30
|
none: false
|
23
|
-
requirement: *5666
|
24
31
|
prerelease: false
|
25
32
|
type: :runtime
|
26
33
|
- !ruby/object:Gem::Dependency
|
27
34
|
name: ffi
|
28
|
-
version_requirements:
|
35
|
+
version_requirements: !ruby/object:Gem::Requirement
|
36
|
+
requirements:
|
37
|
+
- - ">="
|
38
|
+
- !ruby/object:Gem::Version
|
39
|
+
version: !binary |-
|
40
|
+
MA==
|
41
|
+
none: false
|
42
|
+
requirement: !ruby/object:Gem::Requirement
|
29
43
|
requirements:
|
30
|
-
- -
|
44
|
+
- - ">="
|
31
45
|
- !ruby/object:Gem::Version
|
32
|
-
version:
|
46
|
+
version: !binary |-
|
47
|
+
MA==
|
33
48
|
none: false
|
34
|
-
requirement: *5684
|
35
49
|
prerelease: false
|
36
50
|
type: :runtime
|
37
51
|
- !ruby/object:Gem::Dependency
|
38
52
|
name: multi_json
|
39
|
-
version_requirements:
|
53
|
+
version_requirements: !ruby/object:Gem::Requirement
|
40
54
|
requirements:
|
41
|
-
- -
|
55
|
+
- - ">="
|
42
56
|
- !ruby/object:Gem::Version
|
43
|
-
version:
|
57
|
+
version: !binary |-
|
58
|
+
MA==
|
59
|
+
none: false
|
60
|
+
requirement: !ruby/object:Gem::Requirement
|
61
|
+
requirements:
|
62
|
+
- - ">="
|
63
|
+
- !ruby/object:Gem::Version
|
64
|
+
version: !binary |-
|
65
|
+
MA==
|
44
66
|
none: false
|
45
|
-
requirement: *5700
|
46
67
|
prerelease: false
|
47
68
|
type: :runtime
|
48
69
|
- !ruby/object:Gem::Dependency
|
49
70
|
name: thor
|
50
|
-
version_requirements:
|
71
|
+
version_requirements: !ruby/object:Gem::Requirement
|
72
|
+
requirements:
|
73
|
+
- - ">="
|
74
|
+
- !ruby/object:Gem::Version
|
75
|
+
version: !binary |-
|
76
|
+
MA==
|
77
|
+
none: false
|
78
|
+
requirement: !ruby/object:Gem::Requirement
|
51
79
|
requirements:
|
52
|
-
- -
|
80
|
+
- - ">="
|
53
81
|
- !ruby/object:Gem::Version
|
54
|
-
version:
|
82
|
+
version: !binary |-
|
83
|
+
MA==
|
55
84
|
none: false
|
56
|
-
requirement: *5716
|
57
85
|
prerelease: false
|
58
86
|
type: :runtime
|
59
87
|
- !ruby/object:Gem::Dependency
|
60
88
|
name: eventmachine
|
61
|
-
version_requirements:
|
89
|
+
version_requirements: !ruby/object:Gem::Requirement
|
90
|
+
requirements:
|
91
|
+
- - ">="
|
92
|
+
- !ruby/object:Gem::Version
|
93
|
+
version: !binary |-
|
94
|
+
MA==
|
95
|
+
none: false
|
96
|
+
requirement: !ruby/object:Gem::Requirement
|
62
97
|
requirements:
|
63
|
-
- -
|
98
|
+
- - ">="
|
64
99
|
- !ruby/object:Gem::Version
|
65
|
-
version:
|
100
|
+
version: !binary |-
|
101
|
+
MA==
|
66
102
|
none: false
|
67
|
-
requirement: *5732
|
68
103
|
prerelease: false
|
69
104
|
type: :development
|
70
105
|
- !ruby/object:Gem::Dependency
|
71
106
|
name: ffi-rzmq
|
72
|
-
version_requirements:
|
107
|
+
version_requirements: !ruby/object:Gem::Requirement
|
73
108
|
requirements:
|
74
|
-
- -
|
109
|
+
- - ">="
|
75
110
|
- !ruby/object:Gem::Version
|
76
|
-
version:
|
111
|
+
version: !binary |-
|
112
|
+
MA==
|
113
|
+
none: false
|
114
|
+
requirement: !ruby/object:Gem::Requirement
|
115
|
+
requirements:
|
116
|
+
- - ">="
|
117
|
+
- !ruby/object:Gem::Version
|
118
|
+
version: !binary |-
|
119
|
+
MA==
|
77
120
|
none: false
|
78
|
-
requirement: *5750
|
79
121
|
prerelease: false
|
80
122
|
type: :development
|
81
123
|
- !ruby/object:Gem::Dependency
|
82
124
|
name: pry
|
83
|
-
version_requirements:
|
125
|
+
version_requirements: !ruby/object:Gem::Requirement
|
126
|
+
requirements:
|
127
|
+
- - ">="
|
128
|
+
- !ruby/object:Gem::Version
|
129
|
+
version: !binary |-
|
130
|
+
MA==
|
131
|
+
none: false
|
132
|
+
requirement: !ruby/object:Gem::Requirement
|
84
133
|
requirements:
|
85
|
-
- -
|
134
|
+
- - ">="
|
86
135
|
- !ruby/object:Gem::Version
|
87
|
-
version:
|
136
|
+
version: !binary |-
|
137
|
+
MA==
|
88
138
|
none: false
|
89
|
-
requirement: *5766
|
90
139
|
prerelease: false
|
91
140
|
type: :development
|
92
141
|
- !ruby/object:Gem::Dependency
|
93
142
|
name: pry-nav
|
94
|
-
version_requirements:
|
143
|
+
version_requirements: !ruby/object:Gem::Requirement
|
95
144
|
requirements:
|
96
|
-
- -
|
145
|
+
- - ">="
|
97
146
|
- !ruby/object:Gem::Version
|
98
|
-
version:
|
147
|
+
version: !binary |-
|
148
|
+
MA==
|
149
|
+
none: false
|
150
|
+
requirement: !ruby/object:Gem::Requirement
|
151
|
+
requirements:
|
152
|
+
- - ">="
|
153
|
+
- !ruby/object:Gem::Version
|
154
|
+
version: !binary |-
|
155
|
+
MA==
|
99
156
|
none: false
|
100
|
-
requirement: *5782
|
101
157
|
prerelease: false
|
102
158
|
type: :development
|
103
159
|
- !ruby/object:Gem::Dependency
|
104
160
|
name: rake
|
105
|
-
version_requirements:
|
161
|
+
version_requirements: !ruby/object:Gem::Requirement
|
162
|
+
requirements:
|
163
|
+
- - ">="
|
164
|
+
- !ruby/object:Gem::Version
|
165
|
+
version: !binary |-
|
166
|
+
MA==
|
167
|
+
none: false
|
168
|
+
requirement: !ruby/object:Gem::Requirement
|
106
169
|
requirements:
|
107
|
-
- -
|
170
|
+
- - ">="
|
108
171
|
- !ruby/object:Gem::Version
|
109
|
-
version:
|
172
|
+
version: !binary |-
|
173
|
+
MA==
|
110
174
|
none: false
|
111
|
-
requirement: *5798
|
112
175
|
prerelease: false
|
113
176
|
type: :development
|
114
177
|
- !ruby/object:Gem::Dependency
|
115
178
|
name: rake-compiler
|
116
|
-
version_requirements:
|
179
|
+
version_requirements: !ruby/object:Gem::Requirement
|
180
|
+
requirements:
|
181
|
+
- - ">="
|
182
|
+
- !ruby/object:Gem::Version
|
183
|
+
version: !binary |-
|
184
|
+
MA==
|
185
|
+
none: false
|
186
|
+
requirement: !ruby/object:Gem::Requirement
|
117
187
|
requirements:
|
118
|
-
- -
|
188
|
+
- - ">="
|
119
189
|
- !ruby/object:Gem::Version
|
120
|
-
version:
|
190
|
+
version: !binary |-
|
191
|
+
MA==
|
121
192
|
none: false
|
122
|
-
requirement: *5814
|
123
193
|
prerelease: false
|
124
194
|
type: :development
|
125
195
|
- !ruby/object:Gem::Dependency
|
126
196
|
name: rspec
|
127
|
-
version_requirements:
|
197
|
+
version_requirements: !ruby/object:Gem::Requirement
|
128
198
|
requirements:
|
129
|
-
- -
|
199
|
+
- - ">="
|
130
200
|
- !ruby/object:Gem::Version
|
131
|
-
version:
|
201
|
+
version: !binary |-
|
202
|
+
MA==
|
203
|
+
none: false
|
204
|
+
requirement: !ruby/object:Gem::Requirement
|
205
|
+
requirements:
|
206
|
+
- - ">="
|
207
|
+
- !ruby/object:Gem::Version
|
208
|
+
version: !binary |-
|
209
|
+
MA==
|
132
210
|
none: false
|
133
|
-
requirement: *5830
|
134
211
|
prerelease: false
|
135
212
|
type: :development
|
136
213
|
- !ruby/object:Gem::Dependency
|
137
214
|
name: simplecov
|
138
|
-
version_requirements:
|
215
|
+
version_requirements: !ruby/object:Gem::Requirement
|
216
|
+
requirements:
|
217
|
+
- - ">="
|
218
|
+
- !ruby/object:Gem::Version
|
219
|
+
version: !binary |-
|
220
|
+
MA==
|
221
|
+
none: false
|
222
|
+
requirement: !ruby/object:Gem::Requirement
|
139
223
|
requirements:
|
140
|
-
- -
|
224
|
+
- - ">="
|
141
225
|
- !ruby/object:Gem::Version
|
142
|
-
version:
|
226
|
+
version: !binary |-
|
227
|
+
MA==
|
143
228
|
none: false
|
144
|
-
requirement: *5846
|
145
229
|
prerelease: false
|
146
230
|
type: :development
|
147
231
|
- !ruby/object:Gem::Dependency
|
148
232
|
name: yard
|
149
|
-
version_requirements:
|
233
|
+
version_requirements: !ruby/object:Gem::Requirement
|
150
234
|
requirements:
|
151
|
-
- -
|
235
|
+
- - ">="
|
152
236
|
- !ruby/object:Gem::Version
|
153
|
-
version:
|
237
|
+
version: !binary |-
|
238
|
+
MA==
|
239
|
+
none: false
|
240
|
+
requirement: !ruby/object:Gem::Requirement
|
241
|
+
requirements:
|
242
|
+
- - ">="
|
243
|
+
- !ruby/object:Gem::Version
|
244
|
+
version: !binary |-
|
245
|
+
MA==
|
154
246
|
none: false
|
155
|
-
requirement: *5862
|
156
247
|
prerelease: false
|
157
248
|
type: :development
|
158
249
|
description: Google Protocol Buffers v2.4.1 Serialization and RPC implementation for Ruby.
|
@@ -165,9 +256,9 @@ executables:
|
|
165
256
|
extensions: []
|
166
257
|
extra_rdoc_files: []
|
167
258
|
files:
|
168
|
-
- .gitignore
|
169
|
-
- .travis.yml
|
170
|
-
- .yardopts
|
259
|
+
- ".gitignore"
|
260
|
+
- ".travis.yml"
|
261
|
+
- ".yardopts"
|
171
262
|
- Gemfile
|
172
263
|
- README.md
|
173
264
|
- Rakefile
|
@@ -426,109 +517,29 @@ require_paths:
|
|
426
517
|
- lib
|
427
518
|
required_ruby_version: !ruby/object:Gem::Requirement
|
428
519
|
requirements:
|
429
|
-
- -
|
520
|
+
- - ">="
|
430
521
|
- !ruby/object:Gem::Version
|
431
522
|
segments:
|
432
523
|
- 0
|
433
524
|
hash: 2
|
434
|
-
version:
|
525
|
+
version: !binary |-
|
526
|
+
MA==
|
435
527
|
none: false
|
436
528
|
required_rubygems_version: !ruby/object:Gem::Requirement
|
437
529
|
requirements:
|
438
|
-
- -
|
530
|
+
- - ">="
|
439
531
|
- !ruby/object:Gem::Version
|
440
532
|
segments:
|
441
533
|
- 0
|
442
534
|
hash: 2
|
443
|
-
version:
|
535
|
+
version: !binary |-
|
536
|
+
MA==
|
444
537
|
none: false
|
445
538
|
requirements: []
|
446
539
|
rubyforge_project:
|
447
|
-
rubygems_version: 1.8.
|
540
|
+
rubygems_version: 1.8.24
|
448
541
|
signing_key:
|
449
542
|
specification_version: 3
|
450
543
|
summary: Google Protocol Buffers v2.4.1 Serialization and RPC implementation for Ruby.
|
451
|
-
test_files:
|
452
|
-
- spec/benchmark/tasks.rb
|
453
|
-
- spec/functional/embedded_service_spec.rb
|
454
|
-
- spec/functional/evented_server_spec.rb
|
455
|
-
- spec/functional/socket_server_spec.rb
|
456
|
-
- spec/functional/zmq_server_spec.rb
|
457
|
-
- spec/lib/protobuf/cli_spec.rb
|
458
|
-
- spec/lib/protobuf/enum_spec.rb
|
459
|
-
- spec/lib/protobuf/enum_value_spec.rb
|
460
|
-
- spec/lib/protobuf/field/int32_field_spec.rb
|
461
|
-
- spec/lib/protobuf/logger_spec.rb
|
462
|
-
- spec/lib/protobuf/message_spec.rb
|
463
|
-
- spec/lib/protobuf/rpc/client_spec.rb
|
464
|
-
- spec/lib/protobuf/rpc/connector_spec.rb
|
465
|
-
- spec/lib/protobuf/rpc/connectors/base_spec.rb
|
466
|
-
- spec/lib/protobuf/rpc/connectors/common_spec.rb
|
467
|
-
- spec/lib/protobuf/rpc/connectors/socket_spec.rb
|
468
|
-
- spec/lib/protobuf/rpc/connectors/zmq_spec.rb
|
469
|
-
- spec/lib/protobuf/rpc/servers/evented_server_spec.rb
|
470
|
-
- spec/lib/protobuf/rpc/servers/socket_server_spec.rb
|
471
|
-
- spec/lib/protobuf/rpc/servers/zmq/broker_spec.rb
|
472
|
-
- spec/lib/protobuf/rpc/servers/zmq/server_spec.rb
|
473
|
-
- spec/lib/protobuf/rpc/servers/zmq/util_spec.rb
|
474
|
-
- spec/lib/protobuf/rpc/servers/zmq/worker_spec.rb
|
475
|
-
- spec/lib/protobuf/rpc/service_dispatcher_spec.rb
|
476
|
-
- spec/lib/protobuf/rpc/service_filters_spec.rb
|
477
|
-
- spec/lib/protobuf/rpc/service_spec.rb
|
478
|
-
- spec/lib/protobuf_spec.rb
|
479
|
-
- spec/spec_helper.rb
|
480
|
-
- spec/support/all.rb
|
481
|
-
- spec/support/packed_field.rb
|
482
|
-
- spec/support/server.rb
|
483
|
-
- spec/support/test/enum.pb.rb
|
484
|
-
- spec/support/test/enum.proto
|
485
|
-
- spec/support/test/resource.pb.rb
|
486
|
-
- spec/support/test/resource.proto
|
487
|
-
- spec/support/test/resource_service.rb
|
488
|
-
- spec/support/test_app_file.rb
|
489
|
-
- spec/support/tolerance_matcher.rb
|
490
|
-
- test/data/data.bin
|
491
|
-
- test/data/data_source.py
|
492
|
-
- test/data/types.bin
|
493
|
-
- test/data/types_source.py
|
494
|
-
- test/data/unk.png
|
495
|
-
- test/proto/addressbook.pb.rb
|
496
|
-
- test/proto/addressbook.proto
|
497
|
-
- test/proto/addressbook_base.pb.rb
|
498
|
-
- test/proto/addressbook_base.proto
|
499
|
-
- test/proto/addressbook_ext.pb.rb
|
500
|
-
- test/proto/addressbook_ext.proto
|
501
|
-
- test/proto/collision.pb.rb
|
502
|
-
- test/proto/collision.proto
|
503
|
-
- test/proto/ext_collision.pb.rb
|
504
|
-
- test/proto/ext_collision.proto
|
505
|
-
- test/proto/ext_range.pb.rb
|
506
|
-
- test/proto/ext_range.proto
|
507
|
-
- test/proto/float_default.proto
|
508
|
-
- test/proto/lowercase.pb.rb
|
509
|
-
- test/proto/lowercase.proto
|
510
|
-
- test/proto/merge.pb.rb
|
511
|
-
- test/proto/merge.proto
|
512
|
-
- test/proto/nested.pb.rb
|
513
|
-
- test/proto/nested.proto
|
514
|
-
- test/proto/optional_field.pb.rb
|
515
|
-
- test/proto/optional_field.proto
|
516
|
-
- test/proto/packed.pb.rb
|
517
|
-
- test/proto/packed.proto
|
518
|
-
- test/proto/rpc.proto
|
519
|
-
- test/proto/types.pb.rb
|
520
|
-
- test/proto/types.proto
|
521
|
-
- test/test_addressbook.rb
|
522
|
-
- test/test_enum_value.rb
|
523
|
-
- test/test_extension.rb
|
524
|
-
- test/test_lowercase.rb
|
525
|
-
- test/test_message.rb
|
526
|
-
- test/test_optional_field.rb
|
527
|
-
- test/test_packed_field.rb
|
528
|
-
- test/test_parse.rb
|
529
|
-
- test/test_repeated_types.rb
|
530
|
-
- test/test_serialize.rb
|
531
|
-
- test/test_standard_message.rb
|
532
|
-
- test/test_types.rb
|
544
|
+
test_files: []
|
533
545
|
has_rdoc:
|
534
|
-
...
|