ctrl+shift+p filters: :st2 :st3 :win :osx :linux
Browse

Find​In​Files-addon

by kaste ST4

Add-on for Sublime Text's Find-In-Files-feature

Labels find, add-on

Details

Installs

  • Total 91
  • Win 47
  • Mac 31
  • Linux 13
Apr 6 Apr 5 Apr 4 Apr 3 Apr 2 Apr 1 Mar 31 Mar 30 Mar 29 Mar 28 Mar 27 Mar 26 Mar 25 Mar 24 Mar 23 Mar 22 Mar 21 Mar 20 Mar 19 Mar 18 Mar 17 Mar 16 Mar 15 Mar 14 Mar 13 Mar 12 Mar 11 Mar 10 Mar 9 Mar 8 Mar 7 Mar 6 Mar 5 Mar 4 Mar 3 Mar 2 Mar 1 Feb 28 Feb 27 Feb 26 Feb 25 Feb 24 Feb 23 Feb 22 Feb 21
Windows 0 0 0 0 0 0 0 1 1 1 0 0 1 0 0 0 0 2 2 0 0 0 0 1 0 0 1 0 0 0 0 1 0 1 1 0 0 0 1 0 0 1 0 1 0
Mac 0 0 1 1 0 0 0 0 0 0 0 0 0 0 0 0 1 0 0 0 0 0 0 0 0 0 1 0 0 0 2 0 0 0 0 0 0 0 0 0 0 0 1 3 0
Linux 0 1 0 1 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 0 1 0 0 1 0 0 0 0 0 0 1 0 0 0 0 0 0

Readme

Source
raw.​githubusercontent.​com

Find in Files add-on for Sublime Text

This plugin enhances the Find in Files feature of Sublime Text. It attaches to the result buffer automatically and adds the following features:

  1. Make all lines in a find-in-files result buffer double-clickable. Bind <enter> to do the same thing, namely go to that line. (But also set the column, well … just set the complete selection.)

  2. Also, register the filenames as local symbols for quick navigation and outlines. Use ctrl|super+r (Sublime's default) to open the symbols panel, or however you use that in your daily routine. (E.g. I have a global shortcut to jump from symbol to symbol.)

  3. Bind , and . to go to the previous or next match staying in the result buffer. Just move the cursor (“navigate”) around.

    But you can also bind fif_addon_prev_match and fif_addon_next_match on your own.

  4. Bind ctrl+enter to open a preview, side-by-side. The preview will update when you navigate around. Both, enter and ctrl+enter will close the preview. As there is no side-by-side to a results panel, this will only work for result buffers. Also, if you already use the newish “find_in_files_side_by_side” setting, there is no real difference as you already opted-in to always use a side-by-side view. (Hint: Turn find_in_files_side_by_side off and use the preview feature here.)

  5. Bind + and - to change the number of context lines. For ease of use, hit - repeatedly as a toggle between no context and your default, or if your default is no context between that and some context.

  6. Bind f5 to refresh the view, t.i. redo the last search. Hm, 🤔, maybe we can change that and redo the search the cursor is currently in. But for now it is the last search in the buffer.

  7. Bind alt+c[3] to toggle case sensitivity, alt-w to toggle the whole word flag and redo the search immediately.

  8. Bind alt+r to toggle regex mode. The pattern will be escaped/unescaped and the panel will open to edit the pattern further.

  9. If you reuse the result buffer (and it is a tab, not the panel thing at the bottom of the window), the tab moves with you so that closing the tab (aka ctrl+w) brings you to the view where you initiated the search.

  10. Add the search summary (e.g. “2 matches across 2 files”) to the search header line (“Searching 9 files for …”)

  11. Re-bind ctrl+shift+f to immediately do the search if you have exactly one selection. Exclude untitled buffers in that case. (You can turn this off by setting "leave_my_keys_alone.FindInFiles-addon": true in the user preferences.) Sets “whole_word” if you've selected a whole word, unsets it if that's not the case. Also normalizes case_sensitive and regex to false.

[1] On Mac, the standard super+alt modifier is used. Generally, these should be just the standard bindings, you already use in the Find-panel to toggle the switches.

1

Registering “local symbols” populates the Goto panel. I use it in combination with the InlineOutline plugin, which looks like so:

Outline View using InlineOutline

2

I personally like it when escape closes the results view. You can add that to your own key bindings. E.g.

{
        "keys": ["escape"],
        "command": "fif_addon_goto_abort_search",
        "context": [
            { "key": "selector", "operand": "text.find-in-files" },
            // negate all default escape contexts, even if they're not likely to ever match
            // adjust to your liking
            { "key": "auto_complete_visible", "operator": "not_equal" },
            { "key": "has_next_field", "operator": "not_equal" },
            { "key": "has_prev_field", "operator": "not_equal" },
            { "key": "num_selections", "operator": "equal", "operand": 1 },
            { "key": "overlay_visible", "operator": "not_equal" },
            { "key": "panel_has_focus", "operator": "not_equal" },
            { "key": "panel_visible", "operator": "not_equal" },
            { "key": "popup_visible", "operator": "not_equal" },
        ]
    }

The command fif_addon_goto_abort_search basically is like close, just that it also closes the preview if any is open.