[#45426] [ruby-trunk - Feature #6546][Open] Net::HTTP to check for HTTP_PROXY environment setting. — "dekz (Jacob Evans)" <dekzter@...>

14 messages 2012/06/04

[#45431] [ruby-trunk - Bug #6548][Open] Rake doesn't ignore arguments after -- — "rosenfeld (Rodrigo Rosenfeld Rosas)" <rr.rosas@...>

12 messages 2012/06/05

[#45474] [ANN] Request for "slide-show" of your feature proposal — Yusuke Endoh <mame@...>

(Japanese later; 日本語が後にあります)

18 messages 2012/06/07

[#45563] [ruby-trunk - Bug #6573][Open] Webrick test failures — "bkabrda (Bohuslav Kabrda)" <bkabrda@...>

19 messages 2012/06/11

[#45567] [ruby-trunk - Bug #6575][Open] Thread#kill sets rb_errinfo() to Fixnum 8 after rb_protect(function, data, &error_tag) — ibc (Iñaki Baz Castillo) <ibc@...>

9 messages 2012/06/11

[#45647] [ruby-trunk - Bug #6592][Open] test_call_double(DL::TestDL) fails on ARM HardFP — "vo.x (Vit Ondruch)" <v.ondruch@...>

15 messages 2012/06/14

[#45657] [ruby-trunk - Feature #6594][Open] Integrated Functor — "trans (Thomas Sawyer)" <transfire@...>

20 messages 2012/06/15

[#45664] [ruby-trunk - Bug #6596][Open] New method for Arrays : Array#index — "robin850 (Robin Dupret)" <robin.dupret@...>

20 messages 2012/06/15

[#45694] [ruby-trunk - Feature #6602][Open] Tail call optimization: enable by default? — "ko1 (Koichi Sasada)" <redmine@...>

12 messages 2012/06/18

[#45715] [ruby-trunk - Feature #6609][Open] Toplevel as self extended module — "trans (Thomas Sawyer)" <transfire@...>

17 messages 2012/06/19

[#45732] [ruby-trunk - Bug #6614][Open] GC doesn't collect objects bound to (collectable) proc — "rogerdpack (Roger Pack)" <rogerpack2005@...>

9 messages 2012/06/20

[#45733] [ruby-trunk - Feature #6615][Open] Release GVL in zlib when calling inflate() or deflate() — "drbrain (Eric Hodel)" <drbrain@...7.net>

12 messages 2012/06/21

[#45735] [ruby-trunk - Bug #6616][Open] MinGW: cannot build extensions or run tests due changes in exec_arg? — "luislavena (Luis Lavena)" <luislavena@...>

9 messages 2012/06/21

[#45798] [ruby-trunk - Bug #6634][Open] Deadlock with join and ConditionVariable — "meh. (meh. I don't care)" <meh@...>

20 messages 2012/06/23

[#45805] [ruby-trunk - Feature #6636][Open] Enumerable#size — "marcandre (Marc-Andre Lafortune)" <ruby-core@...>

15 messages 2012/06/23

[#45864] [ruby-trunk - Bug #6647][Open] Exceptions raised in threads should be logged — "headius (Charles Nutter)" <headius@...>

71 messages 2012/06/25

[#45902] [ruby-trunk - Bug #6653][Open] 1.9.2/1.9.3 exhibit SEGV with many threads+tcp connections — "erikh (Erik Hollensbe)" <erik@...>

11 messages 2012/06/26

[#45960] [ruby-trunk - Feature #6669][Open] A method like Hash#map but returns hash — "yhara (Yutaka HARA)" <redmine@...>

18 messages 2012/06/29

[#45963] [ruby-trunk - Feature #6670][Open] str.chars.last should be possible — "yhara (Yutaka HARA)" <redmine@...>

36 messages 2012/06/29

[#46021] [ruby-trunk - Feature #6679][Open] Default Ruby source file encoding to utf-8 — "claytrump (Clay Trump)" <clay.trump@...>

21 messages 2012/06/30

[ruby-core:45639] [Archive91 - Backport #3505][Closed] URI.join and Kernel::URI should accept URI objects

From: "marcandre (Marc-Andre Lafortune)" <ruby-core@...>
Date: 2012-06-14 02:33:27 UTC
List: ruby-core #45639
Issue #3505 has been updated by marcandre (Marc-Andre Lafortune).

Description updated
Status changed from Assigned to Closed


----------------------------------------
Backport #3505: URI.join and Kernel::URI should accept URI objects
https://bugs.ruby-lang.org/issues/3505#change-27236

Author: marcandre (Marc-Andre Lafortune)
Status: Closed
Priority: Normal
Assignee: yugui (Yuki Sonoda)
Category: lib
Target version: 


=begin
 URI.join accepts strings or URI objects, except for the first parameter which must be a string:
 
   rubydev -r uri -e 'p URI.join("http://ruby-lang.org", URI("/foo"))'
   #<URI::HTTP:0x0000010109b418 URL:http://ruby-lang.org/foo>
 
   rubydev -r uri -e 'p URI.join(URI("http://ruby-lang.org"), "/foo")'
   /usr/local/rubydev/lib/ruby/1.9.1/uri/common.rb:156:in `split': bad URI(is not URI?): http://ruby-lang.org (URI::InvalidURIError)
 
 I believe it should accept URI object as first parameter too.
 
 Also, Kernel::URI accept uri strings, but not URI objects:
 
   rubydev -r uri -e 'URI(URI("http://ruby-lang.org"))'
   /usr/local/rubydev/lib/ruby/1.9.1/uri/common.rb:156:in `split': bad URI(is not URI?): http://ruby-lang.org (URI::InvalidURIError)
 
 This corresponds to the documentation, but it is contrary to Kernel::String, Integer, Float, etc... that all accept their own type. The error message is clearly buggy (an URI object is not an invalid uri!).
 
 I believe that Kernel::URI should accept URI objects (and return them).
 
 
 The patch below corrects both and has no impact on test-all nor rubyspec.
 
 I plan to commit it unless there is objection.
 
 Yugui: should I commit it in the 1.9.2 branch too?
 
 Thanks
 
 
 
 diff --git a/lib/uri/common.rb b/lib/uri/common.rb
 index 58fd422..bda6718 100644
 --- a/lib/uri/common.rb
 +++ b/lib/uri/common.rb
 @@ -184,12 +184,16 @@ module URI
        end
      end
  
 -    def join(*str)
 -      u = self.parse(str[0])
 -      str[1 .. -1].each do |x|
 -       u = u.merge(x)
 +    def join(*uris)
 +      case uris[0]
 +      when Generic
 +      when String
 +        uris[0] = self.parse(uris[0])
 +      else
 +        raise ArgumentError,
 +          "bad argument (expected URI object or URI string)"
        end
 -      u
 +      uris.inject :merge
      end
  
      def extract(str, schemes = nil, &block)
 @@ -837,11 +841,20 @@ module URI
  end
  
  module Kernel
 -  # alias for URI.parse.
 +
    #
 -  # This method is introduced at 1.8.2.
 -  def URI(uri_str) # :doc:
 -    URI.parse(uri_str)
 +  # Returns +uri+ converted to a URI object.
 +  #
 +  def URI(uri)
 +    case uri
 +    when URI::Generic
 +      uri
 +    when String
 +      URI.parse(uri)
 +    else
 +      raise ArgumentError,
 +        "bad argument (expected URI object or URI string)"
 +    end
    end
    module_function :URI
  end
=end



-- 
http://bugs.ruby-lang.org/

In This Thread

Prev Next