[#45174] [ruby-trunk - Feature #5959][Assigned] Addrinfo#inspectname — Yui NARUSE <naruse@...>
9 messages
2012/02/02
[#45177] Re: [ruby-trunk - Feature #5959][Assigned] Addrinfo#inspectname
— Tanaka Akira <akr@...>
2012/02/02
2012年2月2日17:16 Yui NARUSE <naruse@airemix.jp>:
[#45178] Re: [ruby-trunk - Feature #5959][Assigned] Addrinfo#inspectname
— Tanaka Akira <akr@...>
2012/02/02
2012年2月2日18:12 Tanaka Akira <akr@fsij.org>:
[#45179] Re: [ruby-trunk - Feature #5959][Assigned] Addrinfo#inspectname
— "NARUSE, Yui" <naruse@...>
2012/02/02
(2012/02/02 18:33), Tanaka Akira wrote:
[#45192] Re: [ruby-trunk - Feature #5959][Assigned] Addrinfo#inspectname
— Tanaka Akira <akr@...>
2012/02/05
2012年2月2日19:13 NARUSE, Yui <naruse@airemix.jp>:
[#45183] Plan to 1.9.3 1st patch release — "NARUSE, Yui" <naruse@...>
もう気分は 2.0 なので正直 1.9.3 とかどうでもいいんですけど(ぇー)、
8 messages
2012/02/03
[#45184] Re: Plan to 1.9.3 1st patch release
— KOSAKI Motohiro <kosaki.motohiro@...>
2012/02/03
> = backport 時のレビューの廃止
[ruby-dev:45247] [ruby-trunk - Feature #1905][Rejected] How about IPAddr#<=> to take care of mask_addr?
From:
Yusuke Endoh <mame@...>
Date:
2012-02-14 13:55:24 UTC
List:
ruby-dev #45247
Issue #1905 has been updated by Yusuke Endoh.
Status changed from Assigned to Rejected
長期間進展がみられないので閉じます。[ruby-core:42391] を参照。
武者さんのメールが抜け落ちていてわかりにくいですね。
[ruby-dev:39381] [ruby-dev:39391]
武者さんの提案する API ([ruby-dev:39391]) のパッチを作ってきたら
取りこんでやらんこともない、という待ち状態と思われます。
しかし長期間パッチが来ていないので、一旦とじさせてもらいます。
パッチができたら reopen なり新チケット作成なりしてください。
FYI: znz さんと同じ問題意識 (ネットマスクで IP が消されると面倒)
は、 https://bugs.ruby-lang.org/issues/1275 でも挙がってました。
もう閉じてしまってますが、やる気がある人は reopen してください。
--
Yusuke Endoh <mame@tsg.ne.jp>
----------------------------------------
Feature #1905: How about IPAddr#<=> to take care of mask_addr?
https://bugs.ruby-lang.org/issues/1905
Author: Nobuhiro IMAI
Status: Rejected
Priority: Low
Assignee: Akinori MUSHA
Category: lib
Target version: 2.0.0
=begin
いまいです。
#1877 はありがとうございました。
IPAddr のインスタンスがハッシュのキーに出来るようになったので、簡単な
Access Control List を書いてみたのですが、
>> RUBY_DESCRIPTION
=> "ruby 1.9.2dev (2009-08-07 trunk 24440) [i686-linux]"
>> acl = {
?> IPAddr.new("192.168.2.0/29") => :admin,
?> IPAddr.new("192.168.2.0/24") => :user,
?> }
=> {#<IPAddr: IPv4:192.168.2.0/255.255.255.248>=>:admin, #<IPAddr: IPv4:192.168.2.0/255.255.255.0>=>:user}
>> acl.select{|r, | r === "192.168.2.56"}.max.last
=> :user
>> acl.select{|r, | r === "192.168.2.1"}.max.last
=> :user
と、ちょっと残念な感じです。<=> で、@addr が同じ場合は @mask_addr の大
きい方が IPAddr として大きいとすると、ネットマスクの長い方が採用される
ようなイメージでうれしい気がするのですが、どうでしょうか?
また、これで(というか元から?) IPAddr#== は不要な気がするのですが、何
か見落としてるでしょうか?
IPAddr.new("192.168.2.0/24") == IPAddr.new("192.168.2.0/32")
が true から false に変わるという仕様変更なのですが、どうでしょうか?
--
Nobuhiro IMAI <nov@yo.rim.or.jp>
Key fingerprint = F39E D552 545D 7C64 D690 F644 5A15 746C BD8E 7106
Index: lib/ipaddr.rb
===================================================================
--- lib/ipaddr.rb (revision 24440)
+++ lib/ipaddr.rb (working copy)
@@ -133,16 +133,10 @@ class IPAddr
# Returns a new ipaddr built by bitwise negation.
def ~
return self.clone.set(addr_mask(~@addr))
end
- # Returns true if two ipaddrs are equal.
- def ==(other)
- other = coerce_other(other)
- return @family == other.family && @addr == other.to_i
- end
-
# Returns a new ipaddr built by masking IP address with the given
# prefixlen/netmask. (e.g. 8, 64, "255.255.255.0", etc.)
def mask(prefixlen)
return self.clone.mask!(prefixlen)
end
@@ -325,11 +319,11 @@ class IPAddr
def <=>(other)
other = coerce_other(other)
return nil if other.family != @family
- return @addr <=> other.to_i
+ return [@addr, @mask_addr] <=> [other.to_i, other.mask_addr]
end
include Comparable
# Checks equality used by Hash.
def eql?(other)
@@ -372,10 +366,12 @@ class IPAddr
af, _to_string(@addr), _to_string(@mask_addr))
end
protected
+ attr_reader :mask_addr
+
def set(addr, *family)
case family[0] ? family[0] : @family
when Socket::AF_INET
if addr < 0 || addr > IN4MASK
raise ArgumentError, "invalid address"
@@ -789,15 +785,24 @@ class TC_Operator < Test::Unit::TestCase
a = ~@in6_addr_any
assert_equal(IN6MASK128, a.to_s)
assert_equal("::", @in6_addr_any.to_s)
end
- def test_equal
- assert_equal(true, @a == IPAddr.new("3ffe:505:2::"))
+ def test_compare
+ assert_equal(true, @a == IPAddr.new("3ffe:505:2::/48"))
+ assert_equal(false, @a == IPAddr.new("3ffe:505:2::"))
assert_equal(false, @a == IPAddr.new("3ffe:505:3::"))
assert_equal(true, @a != IPAddr.new("3ffe:505:3::"))
- assert_equal(false, @a != IPAddr.new("3ffe:505:2::"))
+ assert_equal(false, @a != IPAddr.new("3ffe:505:2::/48"))
+ x = IPAddr.new("3ffe:505:3::/48")
+ y = IPAddr.new("3ffe:505:2::/64")
+ assert_equal(true, @a < x)
+ assert_equal(true, @a < y)
+ assert_equal(false, x < y)
+ min, max = [y, x, @a].minmax
+ assert_equal(@a, min)
+ assert_equal(x, max)
end
def test_mask
a = @a.mask(32)
assert_equal("3ffe:505::", a.to_s)
=end
--
http://bugs.ruby-lang.org/