From be1affd6d16346799c8354119c0455c5121c5bd1 Mon Sep 17 00:00:00 2001 From: Nobuyoshi Nakada Date: Sat, 10 Jun 2023 10:02:28 +0900 Subject: [PATCH 1/4] racc/parser-text.rb depends on Rakefile --- Rakefile | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/Rakefile b/Rakefile index 32b7dd4a..b8b05cbd 100644 --- a/Rakefile +++ b/Rakefile @@ -36,7 +36,7 @@ def jruby? Object.const_defined?(:RUBY_ENGINE) and 'jruby' == RUBY_ENGINE end -file 'lib/racc/parser-text.rb' => ['lib/racc/parser.rb'] do |t| +file 'lib/racc/parser-text.rb' => ['lib/racc/parser.rb', __FILE__] do |t| source = 'lib/racc/parser.rb' text = File.read(source) From 639cd0d191d0f0e7d55ed05325a92aaf90711230 Mon Sep 17 00:00:00 2001 From: Nobuyoshi Nakada Date: Sat, 10 Jun 2023 10:03:29 +0900 Subject: [PATCH 2/4] Assert no warning from parser-text.rb --- test/test_parser_text.rb | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/test/test_parser_text.rb b/test/test_parser_text.rb index 22790bd7..5864c02c 100644 --- a/test/test_parser_text.rb +++ b/test/test_parser_text.rb @@ -4,7 +4,7 @@ module Racc class TestRaccParserText < TestCase def test_parser_text_require assert_not_match(/^require/, Racc::PARSER_TEXT) - ruby "-I#{LIB_DIR}", "-rracc/parser-text", %[-e$:.clear], %[-eeval(Racc::PARSER_TEXT)] + assert_in_out_err(%W[-I#{LIB_DIR} -rracc/parser-text -e$:.clear -eeval(Racc::PARSER_TEXT)]) end end end From f12af30317dee87c6ff23d77153b257cf7a7ed5e Mon Sep 17 00:00:00 2001 From: Nobuyoshi Nakada Date: Sat, 10 Jun 2023 10:03:56 +0900 Subject: [PATCH 3/4] Assert no warning from embedded parser-text.rb --- test/case.rb | 12 ++++++++---- test/test_racc_command.rb | 2 +- 2 files changed, 9 insertions(+), 5 deletions(-) diff --git a/test/case.rb b/test/case.rb index f44bf5e5..7a0703c6 100644 --- a/test/case.rb +++ b/test/case.rb @@ -75,9 +75,9 @@ def assert_debugfile(asset, ok) end end - def assert_exec(asset) + def assert_exec(asset, **opts) file = File.basename(asset, '.y') - ruby "-I#{LIB_DIR}", "#{@TAB_DIR}/#{file}" + ruby "-I#{LIB_DIR}", "-rracc/parser", "#{@TAB_DIR}/#{file}", **opts end def strip_version(source) @@ -101,8 +101,12 @@ def racc(*arg, **opt) ruby "-I#{LIB_DIR}", "-S", RACC, *arg, **opt end - def ruby(*arg, **opt) - assert_ruby_status(["-C", @TEMP_DIR, *arg], **opt) + def ruby(*arg, quiet: false, **opt) + if quiet + assert_in_out_err(["-C", @TEMP_DIR, *arg], **opt) + else + assert_ruby_status(["-C", @TEMP_DIR, *arg], **opt) + end end end end diff --git a/test/test_racc_command.rb b/test/test_racc_command.rb index 5bfebf15..9d2b566b 100644 --- a/test/test_racc_command.rb +++ b/test/test_racc_command.rb @@ -45,7 +45,7 @@ def test_chk_y def test_echk_y assert_compile 'echk.y', '-E' assert_debugfile 'echk.y', [] - assert_exec 'echk.y' + assert_exec 'echk.y', quiet: true end def test_err_y From 31ac4f07a3239769c9dfc5e8017d4f41acaa04bf Mon Sep 17 00:00:00 2001 From: Nobuyoshi Nakada Date: Fri, 9 Jun 2023 15:58:16 +0900 Subject: [PATCH 4/4] Expand embedded paths so that the guards can find it --- Rakefile | 2 +- lib/racc/parserfilegenerator.rb | 4 ++-- 2 files changed, 3 insertions(+), 3 deletions(-) diff --git a/Rakefile b/Rakefile index b8b05cbd..3c353120 100644 --- a/Rakefile +++ b/Rakefile @@ -41,7 +41,7 @@ file 'lib/racc/parser-text.rb' => ['lib/racc/parser.rb', __FILE__] do |t| text = File.read(source) text.gsub!(/^require '(.*)'$/) do - %[unless $".find {|p| p.end_with?('/#$1.rb')}\n$".push '#$1.rb'\n#{File.read("lib/#{$1}.rb")}\nend\n] + %[unless $".find {|p| p.end_with?('/#$1.rb')}\n$".push "\#{__dir__}/#$1.rb"\n#{File.read("lib/#{$1}.rb")}\nend\n] rescue $& end diff --git a/lib/racc/parserfilegenerator.rb b/lib/racc/parserfilegenerator.rb index 7846b584..236ff27d 100644 --- a/lib/racc/parserfilegenerator.rb +++ b/lib/racc/parserfilegenerator.rb @@ -135,8 +135,8 @@ def runtime_source def embed_library(src) line %[###### #{src.filename} begin] - line %[unless $".index '#{src.filename}'] - line %[$".push '#{src.filename}'] + line %[unless $".find {|p| p.end_with?('/#{src.filename}')}] + line %[$".push "\#{__dir__}/#{src.filename}"] put src, @params.convert_line? line %[end] line %[###### #{src.filename} end]