Sha256: 26977e227b400a9726efa53af77e49fa1643235511c48a1b3e71a314420137bc

Contents?: true

Size: 1.68 KB

Versions: 1

Compression:

Stored size: 1.68 KB

Contents

#
# Create scrollable output via less!
#
# This command runs `less` in a subprocess, and gives you the IO to its STDIN pipe
# so that you can communicate with it.
#
# Example:
#
#   lesspipe do |less|
#     50.times { less.puts "Hi mom!" }
#   end
#
# The default less parameters are:
# * Allow colour
# * Don't wrap lines longer than the screen
# * Quit immediately (without paging) if there's less than one screen of text.
#
# You can change these options by passing a hash to `lesspipe`, like so:
#
#   lesspipe(:wrap=>false) { |less| less.puts essay.to_s }
#
# It accepts the following boolean options:
#    :color  => Allow ANSI colour codes?
#    :wrap   => Wrap long lines?
#    :always => Always page, even if there's less than one page of text?
#    :tail   => Seek to the end of the stream
#    :search => <regexp> searches the output using the "/" operator
#
def lesspipe(*args)
  if args.any? and args.last.is_a?(Hash)
    options = args.pop
  else
    options = {}
  end

  output = args.first if args.any?

  # Don't page, just output to STDOUT
  if options[:disabled]
    if output
      puts output
    else
      yield STDOUT
    end
    return
  end

  params = []
  params << "-R" unless options[:color]  == false
  params << "-S" unless options[:wrap]   == true
  params << "-F" unless options[:always] == true
  params << "-X"
  
  if regexp = options[:search]
    params << "+/#{regexp}"
  elsif options[:tail] == true
    params << "+\\>"
    $stderr.puts "Seeking to end of stream..."
  end

  IO.popen("less #{params * ' '}", "w") do |less|
    if output
      less.puts output
    else
      yield less
    end
  end

rescue Errno::EPIPE, Interrupt
  # less just quit -- eat the exception.
end

Version data entries

1 entries across 1 versions & 1 rubygems

Version Path
upm-0.1.12 lib/upm/lesspipe.rb