ReSharper 2023.1 Help

CamelHumps

CamelHumps is a feature that identifies parts of compound names composed according to CamelCase, where each part starts with a capital letter, or when parts of a compound name are separated by underscores. You can type only initial letters of these parts, and ReSharper will find items with matching names automatically.

CamelHumps in search commands

CamelHumps always works in all Search by name commands, namely Search Everywhere/Go to Type, Go To File, Go to File Member, and Go to Symbol. It is very convenient to type initial letters of name parts and get the list of matching items:

ReSharper speeds up the search with CamelHumps
You can type either uppercase or lowercase letters:
ReSharper speeds up the search with CamelHumps

ReSharper can also find CamelCased items that match letters in the query in any order:

ReSharper: order of CamelCase abbreviation
Of course, such items will be placed lower in the results lists if there are items that match both letters and their order in the query.

CamelHumps in editor assistance actions

CamelHumps can also work for Extend/Shrink Selection and other typing assistance commands that ReSharper overrides in Visual Studio:

  • Extend Selection to Next/Previous Word (Ctrl+Shift+Right Arrow / Ctrl+Shift+Left Arrow)

  • Go to Next/Previous Word (Ctrl+Left Arrow / Ctrl+Right Arrow)

  • Delete text from the start of the word to the caret Ctrl+Backspace

  • Delete text from the caret to the end of the word Ctrl+Delete

Enable CamelHumps in typing assistance actions

  1. Select ReSharper | Options from the main menu or press Alt+R O.

  2. Go to the Environment | Editor | Behavior page of ReSharper options.

  3. With the Use CamelHumps checkbox, toggle CamelHumps support in typing assistance features.

  4. Click Save in the Options dialog to apply the modifications and let ReSharper choose where to save them, or save the modifications to a specific settings layer using the Save To list. For more information, see manage and share resharper settings.

If the CamelHumps is enabled, the Extend/Shrink Selection commands take into account parts of compound names. Suppose you have placed the caret in the middle of a compound name with several parts that begin with uppercase letters:

ReSharper: using CamelHumps to extend selection within a word
With CamelHumps, pressing Control+W for the first time selects the current part of the word:
ReSharper: using CamelHumps to extend selection within a word
Only after pressing this keystroke for the second time ReSharper selects the whole word:
ReSharper: using CamelHumps to extend selection within a word
All subsequent presses are processed as usual.

With the Use CamelHumps option enabled, Visual Studio's 'Next/Previous Word' Edit.WordNext/Edit.WordPrevious and 'Extend selection to Next/Previous Word' Edit.WordNextExtend/Edit.WordPreviousExtend commands also work in a different way. When you press Ctrl+Right/Left Arrow or Ctrl+Shift+Right/Left Arrow the caret moves with/without selection to the next/previous character that separates parts of a compound name in the current word, and only after the last part in word, it moves on to the next/previous word.

There is also a way to have both behaviors (respecting and ignoring Camel Case) for 'Next/Previous Word' and 'Extend selection to Next/Previous Word', that is, the default Visual Studio shortcuts (Ctrl+Right/Left Arrow and Ctrl+Shift+Right/Left Arrow) will work ignoring Camel Case and some custom shortcuts will work respecting Camel Case.

To configure it, turn off the Use CamelHumps option in ReSharper settings, and then assign custom shortcuts in Visual Studio options (Tools | Options | Environment | Keyboard) to the following commands:

  • ReSharper_HumpNext – move caret to next hump

  • ReSharper_HumpPrev – move caret to previous hump

  • ReSharper_HumpNextExtend – extend selection to next hump

  • ReSharper_HumpPrevExtend – extend selection to previous hump

Note that with this setup (with the Use CamelHumps option disabled), the Extend/Shrink Selection command will ignore CamelHumps.

CamelHumps in code completion

By default, CamelHumps support is also enabled for Code Completion features, that is, you can start typing a CamelCase abbreviation of a symbol (also in lowercase) and the completion popup will display matched items. If necessary, you can configure this behavior.

Change the way code completion filtering works with CamelHumps

  1. Select ReSharper | Options from the main menu or press Alt+R O, then choose Environment | IntelliSense | Completion Behavior on the left.

  2. Use the Match middle of the identifiers checkbox to toggle CamelHumps support for completion features.

  3. Click Save in the Options dialog to apply the modifications and let ReSharper choose where to save them, or save the modifications to a specific settings layer using the Save To list. For more information, see manage and share resharper settings.

This feature is supported in the following languages and technologies:

Language: C#

Language: VB.NET

Language: C++

Language: HTML

Language: ASP.NET

Language: Razor

Language: JavaScript

Language: TypeScript

Language: CSS

Language: XML

Language: XAML

Language: Resx

Language: Build Scripts

Language: Protobuf

Language: JSON

Feature is available in C#

Feature is available in Visual Basic

Feature is available in C++

Feature is available in HTML

Feature is available in ASP.NET

Feature is available in Razor

Feature is available in JavaScript

Feature is available in TypeScript

Feature is available in CSS

Feature is available in XML

Feature is available in XAML

Feature is available in Resource files

Feature is available in build script files

Feature is available in Protobuf

Feature is available in JSON

The instructions and examples given here address the use of the feature in C#. For details specific to other languages, see corresponding topics in the ReSharper by language section.

Last modified: 24 May 2022