summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorJunegunn Choi <junegunn.c@gmail.com>2014-07-01 01:23:07 +0900
committerJunegunn Choi <junegunn.c@gmail.com>2014-07-01 01:23:07 +0900
commit91401514ab68c3903305bfbb8f731ca8bf3e1c59 (patch)
tree4882188afe26b76aecd5c233e90b1bb5e851eeb3
parent3e91c189aea13472ee1f2757482507c24b9e1ff5 (diff)
parent91d986b6c0dfc7425a964d002415655333dffe4c (diff)
Merge pull request #71 from junegunn/issue-70
Add options: --prompt and --print-query
-rw-r--r--README.md2
-rwxr-xr-xfzf32
-rw-r--r--test/test_fzf.rb83
3 files changed, 67 insertions, 50 deletions
diff --git a/README.md b/README.md
index 10334f8d..e1d4daff 100644
--- a/README.md
+++ b/README.md
@@ -81,12 +81,14 @@ usage: fzf [options]
+2, --no-256 Disable 256-color
--black Use black background
--reverse Reverse orientation
+ --prompt=STR Input prompt (default: '> ')
Scripting
-q, --query=STR Start the finder with the given query
-1, --select-1 Automatically select the only match
-0, --exit-0 Exit immediately when there's no match
-f, --filter=STR Filter mode. Do not start interactive finder.
+ --print-query Print query as the first line
Environment variables
FZF_DEFAULT_COMMAND Default command to use when input is tty
diff --git a/fzf b/fzf
index 465858f9..0472fb53 100755
--- a/fzf
+++ b/fzf
@@ -7,7 +7,7 @@
# / __/ / /_/ __/
# /_/ /___/_/ Fuzzy finder for your shell
#
-# Version: 0.8.6 (Jun 27, 2014)
+# Version: 0.8.6 (Jun 30, 2014)
#
# Author: Junegunn Choi
# URL: https://github.com/junegunn/fzf
@@ -50,8 +50,9 @@ end
class FZF
C = Curses
- attr_reader :rxflag, :sort, :nth, :color, :black, :ansi256, :reverse,
- :mouse, :multi, :query, :select1, :exit0, :filter, :extended
+ attr_reader :rxflag, :sort, :nth, :color, :black, :ansi256, :reverse, :prompt,
+ :mouse, :multi, :query, :select1, :exit0, :filter, :extended,
+ :print_query
def sync
@shr_mtx.synchronize { yield }
@@ -91,7 +92,9 @@ class FZF
@nth = nil
@delim = nil
@reverse = false
+ @prompt = '> '
@shr_mtx = Mutex.new
+ @print_query = false
argv =
if opts = ENV['FZF_DEFAULT_OPTS']
@@ -127,7 +130,7 @@ class FZF
when '+0', '--no-exit-0' then @exit0 = false
when '-q', '--query'
usage 1, 'query string required' unless query = argv.shift
- @query = query.dup
+ @query = query
when /^-q(.*)$/, /^--query=(.*)$/
@query = $1
when '-f', '--filter'
@@ -151,6 +154,13 @@ class FZF
@sort = sort.to_i
when /^-s([0-9]+)$/, /^--sort=([0-9]+)$/
@sort = $1.to_i
+ when '--prompt'
+ usage 1, 'prompt string required' unless prompt = argv.shift
+ @prompt = prompt
+ when /^--prompt=(.*)$/
+ @prompt = $1
+ when '--print-query' then @print_query = true
+ when '--no-print-query' then @print_query = false
when '-e', '--extended-exact' then @extended = :exact
when '+e', '--no-extended-exact' then @extended = nil
else
@@ -220,9 +230,11 @@ class FZF
len = empty ? get(:@count) : matches.length
if loaded
if @select1 && len == 1
+ puts @query if @print_query
puts empty ? matches.first : matches.first.first
exit 0
elsif @exit0 && len == 0
+ puts @query if @print_query
exit 0
end
end
@@ -243,6 +255,7 @@ class FZF
end
def filter_list list
+ puts @filter if @print_query
matches = matcher.match(list, @filter, '', '')
if @sort && matches.length <= @sort
matches = FZF.sort(matches)
@@ -314,12 +327,14 @@ class FZF
+2, --no-256 Disable 256-color
--black Use black background
--reverse Reverse orientation
+ --prompt=STR Input prompt (default: '> ')
Scripting
-q, --query=STR Start the finder with the given query
-1, --select-1 Automatically select the only match
-0, --exit-0 Exit immediately when there's no match
-f, --filter=STR Filter mode. Do not start interactive finder.
+ --print-query Print query as the first line
Environment variables
FZF_DEFAULT_COMMAND Default command to use when input is tty
@@ -352,7 +367,7 @@ class FZF
def print_input
C.setpos cursor_y, 0
C.clrtoeol
- cprint '> ', color(:prompt, true)
+ cprint @prompt, color(:prompt, true)
C.attron(C::A_BOLD) do
C.addstr get(:@query)
end
@@ -382,7 +397,7 @@ class FZF
def refresh
query, xcur = geta(:@query, :@xcur)
- C.setpos cursor_y, 2 + width(query[0, xcur])
+ C.setpos cursor_y, @prompt.length + width(query[0, xcur])
C.refresh
end
@@ -1004,7 +1019,7 @@ class FZF
x, y, shift = val.values_at :x, :y, :shift
y = @reverse ? (C.lines - 1 - y) : y
if y == C.lines - 1
- cursor = [0, [input.length, x - 2].min].max
+ cursor = [0, [input.length, x - @prompt.length].min].max
elsif x > 1 && y <= max_items
tv = get(:@yoff) + max_items - y - 1
@@ -1047,8 +1062,9 @@ class FZF
end
ensure
C.close_screen
+ q, selects = geta(:@query, :@selects)
+ @stdout.puts q if @print_query
if got
- selects = call(:@selects, :dup)
if selects.empty?
@stdout.puts got
else
diff --git a/test/test_fzf.rb b/test/test_fzf.rb
index a67ebd5a..4f9e6e13 100644
--- a/test/test_fzf.rb
+++ b/test/test_fzf.rb
@@ -33,6 +33,8 @@ class TestFZF < MiniTest::Unit::TestCase
assert_equal nil, fzf.filter
assert_equal nil, fzf.extended
assert_equal false, fzf.reverse
+ assert_equal '> ', fzf.prompt
+ assert_equal false, fzf.print_query
end
def test_environment_variables
@@ -43,8 +45,8 @@ class TestFZF < MiniTest::Unit::TestCase
assert_equal nil, fzf.nth
ENV['FZF_DEFAULT_OPTS'] =
- '-x -m -s 10000 -q " hello world " +c +2 --select-1 -0 ' +
- '--no-mouse -f "goodbye world" --black --nth=3,-1,2 --reverse'
+ '-x -m -s 10000 -q " hello world " +c +2 --select-1 -0 ' <<
+ '--no-mouse -f "goodbye world" --black --nth=3,-1,2 --reverse --print-query'
fzf = FZF.new []
assert_equal 10000, fzf.sort
assert_equal ' hello world ',
@@ -60,6 +62,7 @@ class TestFZF < MiniTest::Unit::TestCase
assert_equal true, fzf.select1
assert_equal true, fzf.exit0
assert_equal true, fzf.reverse
+ assert_equal true, fzf.print_query
assert_equal [2..2, -1..-1, 1..1], fzf.nth
end
@@ -67,7 +70,8 @@ class TestFZF < MiniTest::Unit::TestCase
# Long opts
fzf = FZF.new %w[--sort=2000 --no-color --multi +i --query hello --select-1
--exit-0 --filter=howdy --extended-exact
- --no-mouse --no-256 --nth=1 --reverse]
+ --no-mouse --no-256 --nth=1 --reverse --prompt (hi)
+ --print-query]
assert_equal 2000, fzf.sort
assert_equal true, fzf.multi
assert_equal false, fzf.color
@@ -82,13 +86,16 @@ class TestFZF < MiniTest::Unit::TestCase
assert_equal :exact, fzf.extended
assert_equal [0..0], fzf.nth
assert_equal true, fzf.reverse
+ assert_equal '(hi)', fzf.prompt
+ assert_equal true, fzf.print_query
# Long opts (left-to-right)
fzf = FZF.new %w[--sort=2000 --no-color --multi +i --query=hello
--filter a --filter b --no-256 --black --nth -1 --nth -2
--select-1 --exit-0 --no-select-1 --no-exit-0
--no-sort -i --color --no-multi --256
- --reverse --no-reverse]
+ --reverse --no-reverse --prompt (hi) --prompt=(HI)
+ --print-query --no-print-query]
assert_equal nil, fzf.sort
assert_equal false, fzf.multi
assert_equal true, fzf.color
@@ -103,6 +110,8 @@ class TestFZF < MiniTest::Unit::TestCase
assert_equal nil, fzf.extended
assert_equal [-2..-2], fzf.nth
assert_equal false, fzf.reverse
+ assert_equal '(HI)', fzf.prompt
+ assert_equal false, fzf.print_query
# Short opts
fzf = FZF.new %w[-s2000 +c -m +i -qhello -x -fhowdy +2 -n3 -1 -0]
@@ -565,36 +574,43 @@ class TestFZF < MiniTest::Unit::TestCase
end
end
- def test_select_1
- stream = stream_for "Hello\nWorld"
+ def assert_fzf_output opts, given, expected
+ stream = stream_for given
output = StringIO.new
begin
$stdout = output
- FZF.new(%w[--query=ol --select-1], stream).start
+ FZF.new(opts, stream).start
rescue SystemExit => e
assert_equal 0, e.status
- assert_equal 'World', output.string.chomp
+ assert_equal expected, output.string.chomp
ensure
$stdout = STDOUT
end
end
- def test_select_1_without_query
- stream = stream_for "Hello World"
- output = StringIO.new
+ def test_filter
+ {
+ %w[--filter=ol] => 'World',
+ %w[--filter=ol --print-query] => "ol\nWorld",
+ }.each do |opts, expected|
+ assert_fzf_output opts, "Hello\nWorld", expected
+ end
+ end
- begin
- $stdout = output
- FZF.new(%w[--select-1], stream).start
- rescue SystemExit => e
- assert_equal 0, e.status
- assert_equal 'Hello World', output.string.chomp
- ensure
- $stdout = STDOUT
+ def test_select_1
+ {
+ %w[--query=ol --select-1] => 'World',
+ %w[--query=ol --select-1 --print-query] => "ol\nWorld",
+ }.each do |opts, expected|
+ assert_fzf_output opts, "Hello\nWorld", expected
end
end
+ def test_select_1_without_query
+ assert_fzf_output %w[--select-1], 'Hello World', 'Hello World'
+ end
+
def test_select_1_ambiguity
stream = stream_for "Hello\nWorld"
begin
@@ -609,33 +625,16 @@ class TestFZF < MiniTest::Unit::TestCase
end
def test_exit_0
- stream = stream_for "Hello\nWorld"
- output = StringIO.new
-
- begin
- $stdout = output
- FZF.new(%w[--query=zz --exit-0], stream).start
- rescue SystemExit => e
- assert_equal 0, e.status
- assert_equal '', output.string
- ensure
- $stdout = STDOUT
+ {
+ %w[--query=zz --exit-0] => '',
+ %w[--query=zz --exit-0 --print-query] => 'zz',
+ }.each do |opts, expected|
+ assert_fzf_output opts, "Hello\nWorld", expected
end
end
def test_exit_0_without_query
- stream = stream_for ""
- output = StringIO.new
-
- begin
- $stdout = output
- FZF.new(%w[--exit-0], stream).start
- rescue SystemExit => e
- assert_equal 0, e.status
- assert_equal '', output.string
- ensure
- $stdout = STDOUT
- end
+ assert_fzf_output %w[--exit-0], '', ''
end
def test_ranking_overlap_match_regions