Class: Libuv::UDP
Constant Summary
collapse
- SEND_DATA_ERROR =
"data must be a String".freeze
- TTL_ARGUMENT_ERROR =
"ttl must be an Integer".freeze
- MULTICAST_ARGUMENT_ERROR =
"multicast_address must be a String".freeze
- INTERFACE_ARGUMENT_ERROR =
"interface_address must be a String".freeze
- HANDLE_CLOSED_ERROR =
"unable to send as handle closed".freeze
Constants included
from Net
Net::INET6_ADDRSTRLEN, Net::INET_ADDRSTRLEN, Net::IP_ARGUMENT_ERROR, Net::PORT_ARGUMENT_ERROR
Constants included
from Assertions
Assertions::MSG_NO_PROC
Constants inherited
from Q::Promise
Q::Promise::MAKE_PROMISE
Instance Attribute Summary
Attributes inherited from Handle
#closed, #loop, #storage
Instance Method Summary
collapse
-
#bind(ip, port) ⇒ Object
-
#disable_broadcast ⇒ Object
-
#disable_multicast_loop ⇒ Object
-
#enable_broadcast ⇒ Object
-
#enable_multicast_loop ⇒ Object
-
#initialize(loop) ⇒ UDP
constructor
-
#join(multicast_address, interface_address) ⇒ Object
-
#leave(multicast_address, interface_address) ⇒ Object
-
#multicast_ttl=(ttl) ⇒ Object
-
#open(fd, binding = true, callback = nil, &blk) ⇒ Object
-
#progress(callback = nil, &blk) ⇒ Object
-
#send(ip, port, data) ⇒ Object
-
#sockname ⇒ Object
-
#start_read ⇒ Object
Starts reading from the handle Renamed to match Stream.
-
#stop_read ⇒ Object
Stops reading from the handle Renamed to match Stream.
-
#try_send(ip, port, data) ⇒ Object
-
#ttl=(ttl) ⇒ Object
Methods inherited from Handle
#active?, #close, #closing?, #ref, #unref
Methods included from Assertions
#assert_block, #assert_boolean, #assert_type
Methods included from Resource
#check_result, #check_result!, #resolve, #to_ptr
#resolved?, #then
Methods inherited from Q::Promise
#catch, #finally
Constructor Details
#initialize(loop) ⇒ UDP
Returns a new instance of UDP.
13
14
15
16
17
18
19
20
21
|
# File 'lib/libuv/udp.rb', line 13
def initialize(loop)
@loop = loop
udp_ptr = ::Libuv::Ext.create_handle(:uv_udp)
error = check_result(::Libuv::Ext.udp_init(loop.handle, udp_ptr))
@request_refs = {}
super(udp_ptr, error)
end
|
Instance Method Details
#bind(ip, port) ⇒ Object
23
24
25
26
27
28
29
30
31
|
# File 'lib/libuv/udp.rb', line 23
def bind(ip, port)
return if @closed
assert_type(String, ip, IP_ARGUMENT_ERROR)
assert_type(Integer, port, PORT_ARGUMENT_ERROR)
sockaddr = create_sockaddr(ip, port)
error = check_result ::Libuv::Ext.udp_bind(handle, sockaddr, 0)
reject(error) if error
end
|
#disable_broadcast ⇒ Object
170
171
172
173
174
|
# File 'lib/libuv/udp.rb', line 170
def disable_broadcast
return if @closed
error = check_result ::Libuv::Ext.udp_set_broadcast(handle, 0)
reject(error) if error
end
|
#disable_multicast_loop ⇒ Object
151
152
153
154
155
|
# File 'lib/libuv/udp.rb', line 151
def disable_multicast_loop
return if @closed
error = check_result ::Libuv::Ext.udp_set_multicast_loop(handle, 0)
reject(error) if error
end
|
#enable_broadcast ⇒ Object
164
165
166
167
168
|
# File 'lib/libuv/udp.rb', line 164
def enable_broadcast
return if @closed
error = check_result ::Libuv::Ext.udp_set_broadcast(handle, 1)
reject(error) if error
end
|
#enable_multicast_loop ⇒ Object
145
146
147
148
149
|
# File 'lib/libuv/udp.rb', line 145
def enable_multicast_loop
return if @closed
error = check_result ::Libuv::Ext.udp_set_multicast_loop(handle, 1)
reject(error) if error
end
|
#join(multicast_address, interface_address) ⇒ Object
46
47
48
49
50
51
52
53
|
# File 'lib/libuv/udp.rb', line 46
def join(multicast_address, interface_address)
return if @closed
assert_type(String, multicast_address, MULTICAST_ARGUMENT_ERROR)
assert_type(String, interface_address, INTERFACE_ARGUMENT_ERROR)
error = check_result ::Libuv::Ext.udp_set_membership(handle, multicast_address, interface_address, :uv_join_group)
reject(error) if error
end
|
#leave(multicast_address, interface_address) ⇒ Object
55
56
57
58
59
60
61
62
|
# File 'lib/libuv/udp.rb', line 55
def leave(multicast_address, interface_address)
return if @closed
assert_type(String, multicast_address, MULTICAST_ARGUMENT_ERROR)
assert_type(String, interface_address, INTERFACE_ARGUMENT_ERROR)
error = check_result ::Libuv::Ext.udp_set_membership(handle, multicast_address, interface_address, :uv_leave_group)
reject(error) if error
end
|
#multicast_ttl=(ttl) ⇒ Object
157
158
159
160
161
162
|
# File 'lib/libuv/udp.rb', line 157
def multicast_ttl=(ttl)
return if @closed
assert_type(Integer, ttl, TTL_ARGUMENT_ERROR)
error = check_result ::Libuv::Ext.udp_set_multicast_ttl(handle, ttl)
reject(error) if error
end
|
#open(fd, binding = true, callback = nil, &blk) ⇒ Object
33
34
35
36
37
|
# File 'lib/libuv/udp.rb', line 33
def open(fd, binding = true, callback = nil, &blk)
return if @closed
error = check_result UV.udp_open(handle, fd)
reject(error) if error
end
|
#progress(callback = nil, &blk) ⇒ Object
183
184
185
|
# File 'lib/libuv/udp.rb', line 183
def progress(callback = nil, &blk)
@progress = callback || blk
end
|
#send(ip, port, data) ⇒ Object
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
|
# File 'lib/libuv/udp.rb', line 103
def send(ip, port, data)
deferred = @loop.defer
if !@closed
begin
assert_type(String, ip, IP_ARGUMENT_ERROR)
assert_type(Integer, port, PORT_ARGUMENT_ERROR)
assert_type(String, data, SEND_DATA_ERROR)
sockaddr = create_sockaddr(ip, port)
req = send_req
buffer1 = ::FFI::MemoryPointer.from_string(data)
buffer = ::Libuv::Ext.buf_init(buffer1, data.respond_to?(:bytesize) ? data.bytesize : data.size)
@request_refs[req.address] = [deferred, buffer1]
error = check_result ::Libuv::Ext.udp_send(
req,
handle,
buffer,
1,
sockaddr,
callback(:send_complete)
)
if error
@request_refs.delete req.address
::Libuv::Ext.free(req)
buffer1.free
deferred.reject(error)
reject(error) end
rescue StandardError => e
deferred.reject(e)
end
else
deferred.reject(RuntimeError.new(HANDLE_CLOSED_ERROR))
end
deferred.promise
end
|
39
40
41
42
43
44
|
# File 'lib/libuv/udp.rb', line 39
def sockname
return [] if @closed
sockaddr, len = get_sockaddr_and_len
check_result! ::Libuv::Ext.udp_getsockname(handle, sockaddr, len)
get_ip_and_port(::Libuv::Ext::Sockaddr.new(sockaddr), len.get_int(0))
end
|
#start_read ⇒ Object
Starts reading from the handle Renamed to match Stream
66
67
68
69
70
|
# File 'lib/libuv/udp.rb', line 66
def start_read
return if @closed
error = check_result ::Libuv::Ext.udp_recv_start(handle, callback(:on_allocate), callback(:on_recv))
reject(error) if error
end
|
#stop_read ⇒ Object
Stops reading from the handle Renamed to match Stream
74
75
76
77
78
|
# File 'lib/libuv/udp.rb', line 74
def stop_read
return if @closed
error = check_result ::Libuv::Ext.udp_recv_stop(handle)
reject(error) if error
end
|
#try_send(ip, port, data) ⇒ Object
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
|
# File 'lib/libuv/udp.rb', line 80
def try_send(ip, port, data)
assert_type(String, ip, IP_ARGUMENT_ERROR)
assert_type(Integer, port, PORT_ARGUMENT_ERROR)
assert_type(String, data, SEND_DATA_ERROR)
sockaddr = create_sockaddr(ip, port)
buffer1 = ::FFI::MemoryPointer.from_string(data)
buffer = ::Libuv::Ext.buf_init(buffer1, data.respond_to?(:bytesize) ? data.bytesize : data.size)
result = ::Libuv::Ext.udp_try_send(
handle,
buffer,
1,
sockaddr
)
buffer1.free
error = check_result result
raise error if error
return result
end
|
#ttl=(ttl) ⇒ Object
176
177
178
179
180
181
|
# File 'lib/libuv/udp.rb', line 176
def ttl=(ttl)
return if @closed
assert_type(Integer, ttl, TTL_ARGUMENT_ERROR)
error = check_result ::Libuv::Ext.udp_set_ttl(handle, Integer(ttl))
reject(error) if error
end
|