Skip to content

Commit

Permalink
Allow override of rm and custom fzf options
Browse files Browse the repository at this point in the history
  • Loading branch information
ollehu committed Oct 15, 2024
1 parent 1bc3014 commit 6ad7054
Show file tree
Hide file tree
Showing 8 changed files with 23 additions and 9 deletions.
7 changes: 7 additions & 0 deletions README.md
Original file line number Diff line number Diff line change
Expand Up @@ -51,6 +51,13 @@ By default fifc override `tab`, but you can assign another keybinding:
set -U fifc_keybinding \cx
```

fifc will also by default use `rm` to remove temporary files, this can changed:

```fish
# Use trash instead of rm
set -U fifc_rm_cmd trash
```

fifc can use modern tools if available:

| Prefer | Fallback to | Used for | Custom options |
Expand Down
8 changes: 8 additions & 0 deletions conf.d/fifc.fish
Original file line number Diff line number Diff line change
Expand Up @@ -11,6 +11,14 @@ if not set --query --universal fifc_open_keybinding
set --universal fifc_open_keybinding ctrl-o
end

if not set --query --universal fifc_rm_cmd
set --universal fifc_rm_cmd rm
end

if not set --query --universal fifc_custom_fzf_opts
set --universal fifc_custom_fzf_opts
end


# Private
set -gx _fifc_comp_count 0
Expand Down
7 changes: 3 additions & 4 deletions functions/_fifc.fish
Original file line number Diff line number Diff line change
Expand Up @@ -3,7 +3,6 @@ function _fifc
set -l result
set -Ux _fifc_extract_regex
set -gx _fifc_complist_path (string join '' (mktemp) "_fifc")
set -gx _fifc_custom_fzf_opts
set -gx fifc_extracted
set -gx fifc_commandline
set -gx fifc_token (commandline --current-token)
Expand Down Expand Up @@ -42,7 +41,8 @@ function _fifc
--preview '_fifc_action preview {} {q}' \
--bind='$fifc_open_keybinding:execute(_fifc_action open {} {q} &> /dev/tty)' \
--query '$fifc_query' \
$_fifc_custom_fzf_opts"
$fifc_custom_fzf_opts"
echo $fzf_cmd

set -l cmd (string join -- " | " $source_cmd $fzf_cmd)
# We use eval hack because wrapping source command
Expand Down Expand Up @@ -79,10 +79,9 @@ function _fifc

commandline --function repaint

rm $_fifc_complist_path
$fifc_rm_cmd $_fifc_complist_path
# Clean state
set -e _fifc_extract_regex
set -e _fifc_custom_fzf_opts
set -e _fifc_complist_path
set -e fifc_token
set -e fifc_group
Expand Down
2 changes: 1 addition & 1 deletion functions/_fifc_action.fish
Original file line number Diff line number Diff line change
Expand Up @@ -53,7 +53,7 @@ function _fifc_action
eval $$comp[$i][4]
break
else if test "$action" = source; and test -n "$$comp[$i][5]"
set _fifc_custom_fzf_opts "$$comp[$i][6]"
set fifc_custom_fzf_opts "$$comp[$i][6]"
if functions "$$comp[$i][5]" 1>/dev/null
eval $$comp[$i][5]
else
Expand Down
2 changes: 1 addition & 1 deletion tests/test_exposed_vars.fish
Original file line number Diff line number Diff line change
Expand Up @@ -40,4 +40,4 @@ set -x fifc_query
set actual (_fifc_action "preview" "$dir/file 1.txt" "1")
@test "exposed vars fifc_query" "$actual" = 1

rm $_fifc_complist_path
$fifc_rm_cmd $_fifc_complist_path
2 changes: 1 addition & 1 deletion tests/test_group.fish
Original file line number Diff line number Diff line change
Expand Up @@ -20,4 +20,4 @@ set actual (_fifc_completion_group)

set -e _fifc_complist
set -e fifc_commandline
rm $_fifc_complist_path
$fifc_rm_cmd $_fifc_complist_path
2 changes: 1 addition & 1 deletion tests/test_match_order.fish
Original file line number Diff line number Diff line change
Expand Up @@ -55,4 +55,4 @@ set actual (_fifc_action "preview" "$dir/file 1.txt")
set -e fifc_commandline
set -gx _fifc_unordered_comp $curr_fifc_unordered_comp
set -gx _fifc_ordered_comp $curr_fifc_ordered_comp
rm $_fifc_complist_path
$fifc_rm_cmd $_fifc_complist_path
2 changes: 1 addition & 1 deletion tests/test_source.fish
Original file line number Diff line number Diff line change
Expand Up @@ -24,4 +24,4 @@ set actual (_fifc_action "source")
set -e fifc_commandline
set -gx _fifc_unordered_comp $curr_fifc_unordered_comp
set -gx _fifc_unordered_comp $curr_fifc_ordered_comp
rm $_fifc_complist_path
$fifc_rm_cmd $_fifc_complist_path

0 comments on commit 6ad7054

Please sign in to comment.