Skip to content

Commit

Permalink
[ruby/irb] Support disabling pager
Browse files Browse the repository at this point in the history
(ruby/irb#783)

With either `IRB.conf[:USE_PAGER] = false` or `--no-pager` commnad line flag.

I decided use `--no-pager` instead of `--use-pager` because it matches with
Pry and git's command line flags.

ruby/irb@df1c3b9042
  • Loading branch information
st0012 authored and matzbot committed Nov 26, 2023
1 parent 0bced53 commit 9cd086b
Show file tree
Hide file tree
Showing 6 changed files with 12 additions and 11 deletions.
3 changes: 3 additions & 0 deletions lib/irb/init.rb
Original file line number Diff line number Diff line change
Expand Up @@ -82,6 +82,7 @@ def IRB.init_config(ap_path)
@CONF[:USE_LOADER] = false
@CONF[:IGNORE_SIGINT] = true
@CONF[:IGNORE_EOF] = false
@CONF[:USE_PAGER] = true
@CONF[:EXTRA_DOC_DIRS] = []
@CONF[:ECHO] = nil
@CONF[:ECHO_ON_ASSIGNMENT] = nil
Expand Down Expand Up @@ -285,6 +286,8 @@ def IRB.parse_opts(argv: ::ARGV)
end
when "--noinspect"
@CONF[:INSPECT_MODE] = false
when "--no-pager"
@CONF[:USE_PAGER] = false
when "--singleline", "--readline", "--legacy"
@CONF[:USE_SINGLELINE] = true
when "--nosingleline", "--noreadline"
Expand Down
1 change: 1 addition & 0 deletions lib/irb/lc/help-message
Original file line number Diff line number Diff line change
Expand Up @@ -22,6 +22,7 @@ Usage: irb.rb [options] [programfile] [arguments]
Show truncated result on assignment (default).
--inspect Use 'inspect' for output.
--noinspect Don't use 'inspect' for output.
--no-pager Don't use pager.
--multiline Use multiline editor module (default).
--nomultiline Don't use multiline editor module.
--singleline Use single line editor module.
Expand Down
2 changes: 1 addition & 1 deletion lib/irb/pager.rb
Original file line number Diff line number Diff line change
Expand Up @@ -18,7 +18,7 @@ def page_content(content)
end

def page
if STDIN.tty? && pager = setup_pager
if IRB.conf[:USE_PAGER] && STDIN.tty? && pager = setup_pager
begin
pid = pager.pid
yield pager
Expand Down
5 changes: 1 addition & 4 deletions test/irb/test_cmd.rb
Original file line number Diff line number Diff line change
Expand Up @@ -23,9 +23,6 @@ def setup
save_encodings
IRB.instance_variable_get(:@CONF).clear
@is_win = (RbConfig::CONFIG['host_os'] =~ /mswin|msys|mingw|cygwin|bccwin|wince|emc/)
STDIN.singleton_class.define_method :tty? do
false
end
end

def teardown
Expand All @@ -34,13 +31,13 @@ def teardown
Dir.chdir(@pwd)
FileUtils.rm_rf(@tmpdir)
restore_encodings
STDIN.singleton_class.remove_method :tty?
end

def execute_lines(*lines, conf: {}, main: self, irb_path: nil)
IRB.init_config(nil)
IRB.conf[:VERBOSE] = false
IRB.conf[:PROMPT_MODE] = :SIMPLE
IRB.conf[:USE_PAGER] = false
IRB.conf.merge!(conf)
input = TestInputMethod.new(lines)
irb = IRB::Irb.new(IRB::WorkSpace.new(main), input)
Expand Down
6 changes: 4 additions & 2 deletions test/irb/test_debug_cmd.rb
Original file line number Diff line number Diff line change
Expand Up @@ -346,9 +346,11 @@ def test_help_command_is_delegated_to_the_debugger
end

def test_show_cmds_display_different_content_when_debugger_is_enabled
write_rc <<~RUBY
IRB.conf[:USE_PAGER] = false
RUBY

write_ruby <<~'ruby'
# disable pager
STDIN.singleton_class.define_method(:tty?) { false }
binding.irb
ruby

Expand Down
6 changes: 2 additions & 4 deletions test/irb/test_irb.rb
Original file line number Diff line number Diff line change
Expand Up @@ -7,8 +7,7 @@ module TestIRB
class InputTest < IntegrationTestCase
def test_symbol_aliases_are_handled_correctly
write_rc <<~RUBY
# disable pager
STDIN.singleton_class.define_method(:tty?) { false }
IRB.conf[:USE_PAGER] = false
RUBY

write_ruby <<~'RUBY'
Expand All @@ -27,8 +26,7 @@ class Foo

def test_symbol_aliases_are_handled_correctly_with_singleline_mode
write_rc <<~RUBY
# disable pager
STDIN.singleton_class.define_method(:tty?) { false }
IRB.conf[:USE_PAGER] = false
IRB.conf[:USE_SINGLELINE] = true
RUBY

Expand Down

0 comments on commit 9cd086b

Please sign in to comment.