ruby-changes:45844
From: naruse <ko1@a...>
Date: Mon, 13 Mar 2017 01:18:11 +0900 (JST)
Subject: [ruby-changes:45844] naruse:r57917 (ruby_2_4): merge revision(s) 57737: [Backport #13225]
naruse 2017-03-13 01:18:06 +0900 (Mon, 13 Mar 2017) New Revision: 57917 https://svn.ruby-lang.org/cgi-bin/viewvc.cgi?view=revision&revision=57917 Log: merge revision(s) 57737: [Backport #13225] date_core.c: expand docs for Date shifting * ext/date/date_core.c: [DOC] expand docs for Date shifting * add examples for Date#>> and Date#<< that clarify some edge cases * add examples for Date#next_year and Date#prev_year * add cross references to Date#>> and Date#<< [ruby-core:79584] [Bug #13225] Modified directories: branches/ruby_2_4/ Modified files: branches/ruby_2_4/ext/date/date_core.c branches/ruby_2_4/version.h Index: ruby_2_4/ext/date/date_core.c =================================================================== --- ruby_2_4/ext/date/date_core.c (revision 57916) +++ ruby_2_4/ext/date/date_core.c (revision 57917) @@ -5969,9 +5969,20 @@ d_lite_next(VALUE self) https://github.com/ruby/ruby/blob/trunk/ruby_2_4/ext/date/date_core.c#L5969 * The argument +n+ should be a numeric value. * * Date.new(2001,2,3) >> 1 #=> #<Date: 2001-03-03 ...> - * Date.new(2001,1,30) >> 1 #=> #<Date: 2001-02-28 ...> - * Date.new(2001,1,31) >> 1 #=> #<Date: 2001-02-28 ...> * Date.new(2001,2,3) >> -2 #=> #<Date: 2000-12-03 ...> + * + * When the same day does not exist for the corresponding month, + * the last day of the month is used instead: + * + * Date.new(2001,1,28) >> 1 #=> #<Date: 2001-02-28 ...> + * Date.new(2001,1,31) >> 1 #=> #<Date: 2001-02-28 ...> + * + * This also results in the following, possibly unexpected, behavior: + * + * Date.new(2001,1,31) >> 2 #=> #<Date: 2001-03-31 ...> + * Date.new(2001,1,31) >> 1 >> 1 #=> #<Date: 2001-03-28 ...> + * + * Date.new(2001,1,31) >> 1 >> -1 #=> #<Date: 2001-01-28 ...> */ static VALUE d_lite_rshift(VALUE self, VALUE other) @@ -6020,9 +6031,20 @@ d_lite_rshift(VALUE self, VALUE other) https://github.com/ruby/ruby/blob/trunk/ruby_2_4/ext/date/date_core.c#L6031 * The argument +n+ should be a numeric value. * * Date.new(2001,2,3) << 1 #=> #<Date: 2001-01-03 ...> - * Date.new(2001,1,30) << 11 #=> #<Date: 2000-02-29 ...> - * Date.new(2001,1,31) << 11 #=> #<Date: 2000-02-29 ...> - * Date.new(2001,2,3) << -1 #=> #<Date: 2001-03-03 ...> + * Date.new(2001,2,3) << -2 #=> #<Date: 2001-04-03 ...> + * + * When the same day does not exist for the corresponding month, + * the last day of the month is used instead: + * + * Date.new(2001,3,28) << 1 #=> #<Date: 2001-02-28 ...> + * Date.new(2001,3,31) << 1 #=> #<Date: 2001-02-28 ...> + * + * This also results in the following, possibly unexpected, behavior: + * + * Date.new(2001,3,31) << 2 #=> #<Date: 2001-01-31 ...> + * Date.new(2001,3,31) << 1 << 1 #=> #<Date: 2001-01-28 ...> + * + * Date.new(2001,3,31) << 1 << -1 #=> #<Date: 2001-03-28 ...> */ static VALUE d_lite_lshift(VALUE self, VALUE other) @@ -6036,6 +6058,8 @@ d_lite_lshift(VALUE self, VALUE other) https://github.com/ruby/ruby/blob/trunk/ruby_2_4/ext/date/date_core.c#L6058 * d.next_month([n=1]) -> date * * This method is equivalent to d >> n. + * + * See Date#>> for examples. */ static VALUE d_lite_next_month(int argc, VALUE *argv, VALUE self) @@ -6053,6 +6077,8 @@ d_lite_next_month(int argc, VALUE *argv, https://github.com/ruby/ruby/blob/trunk/ruby_2_4/ext/date/date_core.c#L6077 * d.prev_month([n=1]) -> date * * This method is equivalent to d << n. + * + * See Date#<< for examples. */ static VALUE d_lite_prev_month(int argc, VALUE *argv, VALUE self) @@ -6070,6 +6096,12 @@ d_lite_prev_month(int argc, VALUE *argv, https://github.com/ruby/ruby/blob/trunk/ruby_2_4/ext/date/date_core.c#L6096 * d.next_year([n=1]) -> date * * This method is equivalent to d >> (n * 12). + * + * Date.new(2001,2,3).next_year #=> #<Date: 2002-02-03 ...> + * Date.new(2008,2,29).next_year #=> #<Date: 2009-02-28 ...> + * Date.new(2008,2,29).next_year(4) #=> #<Date: 2012-02-29 ...> + * + * See also Date#>>. */ static VALUE d_lite_next_year(int argc, VALUE *argv, VALUE self) @@ -6087,6 +6119,12 @@ d_lite_next_year(int argc, VALUE *argv, https://github.com/ruby/ruby/blob/trunk/ruby_2_4/ext/date/date_core.c#L6119 * d.prev_year([n=1]) -> date * * This method is equivalent to d << (n * 12). + * + * Date.new(2001,2,3).prev_year #=> #<Date: 2000-02-03 ...> + * Date.new(2008,2,29).prev_year #=> #<Date: 2007-02-28 ...> + * Date.new(2008,2,29).prev_year(4) #=> #<Date: 2004-02-29 ...> + * + * See also Date#<<. */ static VALUE d_lite_prev_year(int argc, VALUE *argv, VALUE self) Index: ruby_2_4/version.h =================================================================== --- ruby_2_4/version.h (revision 57916) +++ ruby_2_4/version.h (revision 57917) @@ -1,6 +1,6 @@ https://github.com/ruby/ruby/blob/trunk/ruby_2_4/version.h#L1 #define RUBY_VERSION "2.4.0" #define RUBY_RELEASE_DATE "2017-03-13" -#define RUBY_PATCHLEVEL 72 +#define RUBY_PATCHLEVEL 73 #define RUBY_RELEASE_YEAR 2017 #define RUBY_RELEASE_MONTH 3 Property changes on: ruby_2_4 ___________________________________________________________________ Modified: svn:mergeinfo Merged /trunk:r57737 -- ML: ruby-changes@q... Info: http://www.atdot.net/~ko1/quickml/