mirror of
https://github.com/ruby/ruby.git
synced 2022-11-09 12:17:21 -05:00
* lib/time.rb (Time.parse): raise ArgumentError if Date._parse don't
extract date information. [ruby-core:20912] git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/trunk@22318 b2dd03c8-39d4-4d8f-98ff-823fe69b080e
This commit is contained in:
parent
e722ad99d5
commit
1b4c1f715e
4 changed files with 18 additions and 3 deletions
|
@ -1,3 +1,8 @@
|
|||
Sun Feb 15 06:34:22 2009 Tanaka Akira <akr@fsij.org>
|
||||
|
||||
* lib/time.rb (Time.parse): raise ArgumentError if Date._parse don't
|
||||
extract date information. [ruby-core:20912]
|
||||
|
||||
Sun Feb 15 04:48:08 2009 Yusuke Endoh <mame@tsg.ne.jp>
|
||||
|
||||
* string.c (rb_hash_uint32, rb_hash_uint, rb_hash_start, rb_hash_end),
|
||||
|
|
4
NEWS
4
NEWS
|
@ -150,6 +150,10 @@ with all sufficient information, see the ChangeLog file.
|
|||
* Readline.completion_proc= accepts nil.
|
||||
nil means to use default completion proc.
|
||||
|
||||
* time
|
||||
* incompatible changes:
|
||||
* Time.parse raises ArgumentError when no date information.
|
||||
|
||||
=== Compatibility issues (excluding feature bug fixes)
|
||||
|
||||
* Enumerator#rewind
|
||||
|
|
11
lib/time.rb
11
lib/time.rb
|
@ -214,9 +214,11 @@ class Time
|
|||
#
|
||||
# # Suppose it is "Thu Nov 29 14:33:20 GMT 2001" now and
|
||||
# # your timezone is GMT:
|
||||
# Time.parse("16:30") #=> Thu Nov 29 16:30:00 GMT 2001
|
||||
# Time.parse("7/23") #=> Mon Jul 23 00:00:00 GMT 2001
|
||||
# Time.parse("Aug 31") #=> Fri Aug 31 00:00:00 GMT 2001
|
||||
# now =
|
||||
# Time.parse("16:30") #=> 2001-11-29 16:30:00 +0900
|
||||
# Time.parse("7/23") #=> 2001-07-23 00:00:00 +0900
|
||||
# Time.parse("Aug 31") #=> 2001-08-31 00:00:00 +0900
|
||||
# Time.parse("Aug 2000") #=> 2000-08-01 00:00:00 +0900
|
||||
#
|
||||
# Since there are numerous conflicts among locally defined timezone
|
||||
# abbreviations all over the world, this method is not made to
|
||||
|
@ -252,6 +254,9 @@ class Time
|
|||
#
|
||||
def parse(date, now=self.now)
|
||||
d = Date._parse(date, false)
|
||||
if !d[:year] && !d[:mon] && !d[:mday] && !d[:hour] && !d[:min] && !d[:sec] && !d[:sec_fraction]
|
||||
raise ArgumentError, "no time information in #{date.inspect}"
|
||||
end
|
||||
year = d[:year]
|
||||
year = yield(year) if year && block_given?
|
||||
make_time(year, d[:mon], d[:mday], d[:hour], d[:min], d[:sec], d[:sec_fraction], d[:zone], now)
|
||||
|
|
|
@ -176,6 +176,7 @@ class TestTimeExtention < Test::Unit::TestCase # :nodoc:
|
|||
#assert_equal(Time.local(2001,11,1), Time.parse("Nov", now))
|
||||
assert_equal(Time.local( 2001,11,29,10,22),
|
||||
Time.parse( "10:22", now))
|
||||
assert_raise(ArgumentError) { Time.parse("foo", now) }
|
||||
end
|
||||
|
||||
def test_invalid
|
||||
|
|
Loading…
Add table
Reference in a new issue