Using Helix's Global Search

gorilla

Table of Contents

Introduction

This article provides a comprehensive guide on using Helix’s global search, a powerful feature that allows you to search across your entire workspace. You’ll learn how to get started with global search, when to use it, and how to perform basic and advanced searches using regex. Additionally, this article offers tips and tricks to enhance your search efficiency. Written for Helix 25.01.

Global search allows you to search across the entire workspace, unlike standard search, which is limited to the current buffer. This makes global search a powerful tool that can complement language server-based features or be used independently when no language server is available.

Consider using a language server before opting for global search. For example:

Not all language servers offer this functionality, so consult their respective documentation.

When opening the global search picker with Space /, if you’ve performed a standard search using / or ?, the search term is pre-filled from the contents of the search register. You can accept this suggestion by pressing Enter, or enter your own search term, which will replace the suggestion.

In the following example, Enter is pressed to accept the suggestion, and the sentence is found inside a document in the workspace:

pre-filled-search-image selected-search-image

Otherwise, to populate the search register in advance with something other than the last standard search, use one of the following methods:

Pre-selecting a search term from the document

Method 1: Copy text to the search register using *

By default, word boundaries \b are automatically added around the selected text. For example, searching for gorilla will result in \bgorilla\b, preventing the inclusion of similar words like gorillas. If you don’t want this feature you can use Alt-* instead.

Method 2: Yank directly to the search register

This isn’t regex-escaped, unlike when using *.

Method 3: Use the <Selection Contents> register

  1. Select a word with miw.

This selection is automatically copied to the <Selection Contents> register, which uses the . symbol and always contains the current selection.

  1. Open the global search picker with Space /.
  2. Press Ctrl-r. to paste the contents of the <Selection Contents> register.

Note: The regex isn’t escaped.

Using regex

For complex queries, learn about regex features. Unlike other pickers that use fzf search syntax, global search employs regular expression queries (regex). Regex consists of special characters representing rules used to search and match within every file in your project.

Escape special regex characters in search text with \

To select the first column of a Markdown table, you would use ^ to anchor the match at the start of the line and | for the table character. Since | is also used in regex to represent alternation, you must escape it. Therefore, the search pattern would be ^\|.

Here is an example using standard search showing the highlighted selection: standard-search-regex-image

In global search, each line matched would be a separate result:

Commonly used regex characters include:

Regex Description Example
. Matches any single character except newline a.b -> matches “aab”, “abb”, “acb”…
* Matches zero or more of the preceding element ab* -> matches “a”, “ab”, “abb”
+ Matches one or more of the preceding element ab+ -> matches “ab”, “abb”
? Matches zero or one of the preceding element ab? -> matches “a”, “ab”
^ Anchors the match at the start of a line ^abc -> matches “abc” at start
$ Anchors the match at the end of a line abc$ -> matches “abc” at end
| Represents alternation (logical OR) a|b -> matches “a” or “b”

Find the full list of supported regex in the Rust regex crate documentation. Here are some examples of useful regex searches:

Regex example 1: Matching whole words

To find whole words, use \b for word boundaries:

The chimpanzee observed a group of gorillas.
Many gorillas gathered near the chimpanzees.

Adding \b is automated with *, but there maybe situations where you need to add it manually.

Regex example 2: Change case sensitivity on the fly

Helix uses smart-case = true by default, making regex searches case-insensitive unless the pattern contains uppercase characters:

let userName = "Chimpanzee";
let Username = "Gorilla";
let username = "Orangutan";

To change case sensitivity dynamically, use regex flags directly before the search term:

Regex example 3: Searching for functions

To find all function calls (for example foo(), bar(), baz(arg)):

\w+\([^)]*\)

Narrowing your results by path

Different pickers offer various columns to filter your results. By referencing a specific column and adding another search term, you can refine your search more effectively. In global search, there is one additional column available: path.

To select the path column, use the % character followed by an incremental search term. In this case p will suffice as there is only one column that begins with p. Providing your theme supports it, the column should become highlighted in some way.

For example, to search files in your workspace for the string version and then narrow down the results to only include .json files, use the following search:

version %p .json

search JSON files

Tips and tricks

Ignoring files

You can ignore files using .gitignore, global ignore settings, and Helix-specific ignore files, with options for both local and global configurations. Details are in the documentation: https://docs.helix-editor.com/master/editor.html#editorfile-picker-section

As an example, to stop Helix from searching your node_modules in a JavaScript project, simply create a .gitignore in the root of your project:

.gitignore

node_modules/  

Reopening the global search picker in its previous state

Use Space ' to reopen the last used picker in its previous state. This is useful for tasks like refactoring using global search, where you revisit a list of items. Avoid opening other pickers to preserve the state.

Opening results in another window or in the background

In pickers, including the global search picker, you can use specific keys for navigation and actions. Details are in the documentation: https://docs.helix-editor.com/master/keymap.html#picker. Of particular interest are:

Using the / search register in other pickers

The * key can copy search terms for use in other pickers. For example, to search for file names:

  1. Select the file name in your document.
  2. Press * to copy it to the search register.
  3. Open the file picker with Space f and paste using Ctrl-r/.

This method works with any picker and the command mode (:), as you can paste from any register using Ctrl-r.

Conclusion

The Helix global search picker is a versatile tool that enhances your coding efficiency by allowing comprehensive searches across your workspace. The introduction of Nucleo has further improved its functionality, offering dynamic search results. By understanding how to use regex and pre-select search terms, you can tailor your search queries to suit your specific needs. Additionally, tips like ignoring files, reopening pickers in their previous state, and using search registers in other pickers provide further flexibility and convenience. For more advanced usage, consider exploring the documentation and experimenting with the various features discussed in this article.

Join Our Mailing List, Get 20% Off The Course!

logo1

If you are interested in the Mastering the Helix editor course and want to stay updated on the release, we invite you to join our mailing list. By subscribing, you will receive updates on the course progress, release date, and a 20% off discount voucher.

We use Mailchimp for the mailing list, you can unsubscribe at any time by clicking the link in the footer of our emails.

Tags: