From fe0fb03316b049783bcf4ecef2d88385eb401a1b Mon Sep 17 00:00:00 2001 From: nagachika Date: Sat, 11 Jun 2016 17:26:02 +0000 Subject: [PATCH] merge revision(s) 54893: [Backport #10763] * parse.y (new_if_gen): set newline flag to NODE_IF to trace all if/elsif statements. [ruby-core:67720] [Bug #10763] git-svn-id: svn+ssh://ci.ruby-lang.org/ruby/branches/ruby_2_3@55382 b2dd03c8-39d4-4d8f-98ff-823fe69b080e --- ChangeLog | 5 +++++ parse.y | 2 +- test/ruby/test_settracefunc.rb | 19 +++++++++++++++++++ version.h | 8 ++++---- 4 files changed, 29 insertions(+), 5 deletions(-) diff --git a/ChangeLog b/ChangeLog index 2f7f9777a1..17fd4f6f77 100644 --- a/ChangeLog +++ b/ChangeLog @@ -1,3 +1,8 @@ +Sun Jun 12 01:59:33 2016 Nobuyoshi Nakada + + * parse.y (new_if_gen): set newline flag to NODE_IF to trace all + if/elsif statements. [ruby-core:67720] [Bug #10763] + Sun May 15 02:33:52 2016 Nobuyoshi Nakada * lib/mkmf.rb (pkg_config): use xsystem consistently to set up diff --git a/parse.y b/parse.y index ee796a4eb4..27b328e8f4 100644 --- a/parse.y +++ b/parse.y @@ -9947,7 +9947,7 @@ new_if_gen(struct parser_params *parser, NODE *cc, NODE *left, NODE *right) { if (!cc) return right; cc = cond0(parser, cc); - return NEW_IF(cc, left, right); + return newline_node(NEW_IF(cc, left, right)); } static NODE* diff --git a/test/ruby/test_settracefunc.rb b/test/ruby/test_settracefunc.rb index fc1391e60f..7e099401f5 100644 --- a/test/ruby/test_settracefunc.rb +++ b/test/ruby/test_settracefunc.rb @@ -1399,6 +1399,25 @@ class TestSetTraceFunc < Test::Unit::TestCase assert_equal [__LINE__ - 3, __LINE__ - 2], lines, 'Bug #10449' end + def test_elsif_line_event + bug10763 = '[ruby-core:67720] [Bug #10763]' + lines = [] + line = nil + + TracePoint.new(:line){|tp| + next unless target_thread? + lines << tp.lineno if line + }.enable{ + line = __LINE__ + if !line + 1 + elsif line + 2 + end + } + assert_equal [line+1, line+3, line+4], lines, bug10763 + end + class Bug10724 def initialize loop{return} diff --git a/version.h b/version.h index 00f9570676..1236ccdc61 100644 --- a/version.h +++ b/version.h @@ -1,10 +1,10 @@ #define RUBY_VERSION "2.3.2" -#define RUBY_RELEASE_DATE "2016-05-21" -#define RUBY_PATCHLEVEL 120 +#define RUBY_RELEASE_DATE "2016-06-12" +#define RUBY_PATCHLEVEL 121 #define RUBY_RELEASE_YEAR 2016 -#define RUBY_RELEASE_MONTH 5 -#define RUBY_RELEASE_DAY 21 +#define RUBY_RELEASE_MONTH 6 +#define RUBY_RELEASE_DAY 12 #include "ruby/version.h"