io-endpoint 0.6.0 → 0.7.0
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
- checksums.yaml.gz.sig +0 -0
- data/lib/io/endpoint/ssl_endpoint.rb +1 -1
- data/lib/io/endpoint/version.rb +1 -1
- data/lib/io/endpoint.rb +2 -0
- data/lib/io/readable.rb +56 -0
- data.tar.gz.sig +0 -0
- metadata +4 -4
- metadata.gz.sig +0 -0
- data/lib/io/connected.rb +0 -27
checksums.yaml
CHANGED
@@ -1,7 +1,7 @@
|
|
1
1
|
---
|
2
2
|
SHA256:
|
3
|
-
metadata.gz:
|
4
|
-
data.tar.gz:
|
3
|
+
metadata.gz: 3f76dc33db329c9e393c817dbc679a3d06c1f523eda8740edd25447ed39f5a1b
|
4
|
+
data.tar.gz: 3917511b6a08184cad66e734120d8ea039b15645b9f0c1b256a5149372628e56
|
5
5
|
SHA512:
|
6
|
-
metadata.gz:
|
7
|
-
data.tar.gz:
|
6
|
+
metadata.gz: 9b685cf7785946c7a856eaf7859ce6c8427c0ad1df532b188c1049432b474afd289fe7e31eff9ee6c4c608d42022b84e48d4b963de563b83482a6daa572520e8
|
7
|
+
data.tar.gz: f2a96e35cce3eea736e3ac25eabd3674d595753cdfa3caa652f28da4e9793d7d7d51d3518731018ac19716c779092eaea90d51813504cadca6193a64709fe4e1
|
checksums.yaml.gz.sig
CHANGED
Binary file
|
data/lib/io/endpoint/version.rb
CHANGED
data/lib/io/endpoint.rb
CHANGED
data/lib/io/readable.rb
ADDED
@@ -0,0 +1,56 @@
|
|
1
|
+
class IO
|
2
|
+
unless method_defined?(:readable?)
|
3
|
+
def readable?
|
4
|
+
if self.wait_readable(0).nil?
|
5
|
+
# timeout means it is not eof
|
6
|
+
return true
|
7
|
+
else
|
8
|
+
!self.eof?
|
9
|
+
end
|
10
|
+
end
|
11
|
+
end
|
12
|
+
end
|
13
|
+
|
14
|
+
require 'socket'
|
15
|
+
|
16
|
+
class BasicSocket
|
17
|
+
unless method_defined?(:readable?)
|
18
|
+
def readable?
|
19
|
+
# Is it likely that the socket is still connected?
|
20
|
+
# May return false positive, but won't return false negative.
|
21
|
+
return false unless super
|
22
|
+
|
23
|
+
# If we can wait for the socket to become readable, we know that the socket may still be open.
|
24
|
+
result = to_io.recv_nonblock(1, MSG_PEEK, exception: false)
|
25
|
+
|
26
|
+
# No data was available - newer Ruby can return nil instead of empty string:
|
27
|
+
return false if result.nil?
|
28
|
+
|
29
|
+
# Either there was some data available, or we can wait to see if there is data avaialble.
|
30
|
+
return !result.empty? || result == :wait_readable
|
31
|
+
rescue Errno::ECONNRESET
|
32
|
+
# This might be thrown by recv_nonblock.
|
33
|
+
return false
|
34
|
+
end
|
35
|
+
end
|
36
|
+
end
|
37
|
+
|
38
|
+
require 'stringio'
|
39
|
+
|
40
|
+
class StringIO
|
41
|
+
unless method_defined?(:readable?)
|
42
|
+
def readable?
|
43
|
+
!eof?
|
44
|
+
end
|
45
|
+
end
|
46
|
+
end
|
47
|
+
|
48
|
+
require 'openssl'
|
49
|
+
|
50
|
+
class OpenSSL::SSL::SSLSocket
|
51
|
+
unless method_defined?(:readable?)
|
52
|
+
def readable?
|
53
|
+
to_io.readable?
|
54
|
+
end
|
55
|
+
end
|
56
|
+
end
|
data.tar.gz.sig
CHANGED
Binary file
|
metadata
CHANGED
@@ -1,7 +1,7 @@
|
|
1
1
|
--- !ruby/object:Gem::Specification
|
2
2
|
name: io-endpoint
|
3
3
|
version: !ruby/object:Gem::Version
|
4
|
-
version: 0.
|
4
|
+
version: 0.7.0
|
5
5
|
platform: ruby
|
6
6
|
authors:
|
7
7
|
- Samuel Williams
|
@@ -37,7 +37,7 @@ cert_chain:
|
|
37
37
|
Q2K9NVun/S785AP05vKkXZEFYxqG6EW012U4oLcFl5MySFajYXRYbuUpH6AY+HP8
|
38
38
|
voD0MPg1DssDLKwXyt1eKD/+Fq0bFWhwVM/1XiAXL7lyYUyOq24KHgQ2Csg=
|
39
39
|
-----END CERTIFICATE-----
|
40
|
-
date: 2024-
|
40
|
+
date: 2024-04-20 00:00:00.000000000 Z
|
41
41
|
dependencies: []
|
42
42
|
description:
|
43
43
|
email:
|
@@ -45,7 +45,6 @@ executables: []
|
|
45
45
|
extensions: []
|
46
46
|
extra_rdoc_files: []
|
47
47
|
files:
|
48
|
-
- lib/io/connected.rb
|
49
48
|
- lib/io/endpoint.rb
|
50
49
|
- lib/io/endpoint/address_endpoint.rb
|
51
50
|
- lib/io/endpoint/bound_endpoint.rb
|
@@ -59,6 +58,7 @@ files:
|
|
59
58
|
- lib/io/endpoint/unix_endpoint.rb
|
60
59
|
- lib/io/endpoint/version.rb
|
61
60
|
- lib/io/endpoint/wrapper.rb
|
61
|
+
- lib/io/readable.rb
|
62
62
|
- license.md
|
63
63
|
- readme.md
|
64
64
|
homepage: https://github.com/socketry/io-endpoint
|
@@ -81,7 +81,7 @@ required_rubygems_version: !ruby/object:Gem::Requirement
|
|
81
81
|
- !ruby/object:Gem::Version
|
82
82
|
version: '0'
|
83
83
|
requirements: []
|
84
|
-
rubygems_version: 3.5.
|
84
|
+
rubygems_version: 3.5.3
|
85
85
|
signing_key:
|
86
86
|
specification_version: 4
|
87
87
|
summary: Provides a separation of concerns interface for IO endpoints.
|
metadata.gz.sig
CHANGED
Binary file
|
data/lib/io/connected.rb
DELETED
@@ -1,27 +0,0 @@
|
|
1
|
-
require 'socket'
|
2
|
-
|
3
|
-
class IO
|
4
|
-
def connected?
|
5
|
-
!closed?
|
6
|
-
end
|
7
|
-
end
|
8
|
-
|
9
|
-
class Socket
|
10
|
-
def connected?
|
11
|
-
# Is it likely that the socket is still connected?
|
12
|
-
# May return false positive, but won't return false negative.
|
13
|
-
return false unless super
|
14
|
-
|
15
|
-
# If we can wait for the socket to become readable, we know that the socket may still be open.
|
16
|
-
result = to_io.recv_nonblock(1, MSG_PEEK, exception: false)
|
17
|
-
|
18
|
-
# No data was available - newer Ruby can return nil instead of empty string:
|
19
|
-
return false if result.nil?
|
20
|
-
|
21
|
-
# Either there was some data available, or we can wait to see if there is data avaialble.
|
22
|
-
return !result.empty? || result == :wait_readable
|
23
|
-
rescue Errno::ECONNRESET
|
24
|
-
# This might be thrown by recv_nonblock.
|
25
|
-
return false
|
26
|
-
end
|
27
|
-
end
|