Basic completion
Code | Code Completion | Basic
JetBrains Rider's basic completion suggests names of classes, methods, variables, keywords, and any other symbols that are available within the current visibility scope including extension methods that were previously imported. Many other context-specific suggestions, like live templates, code generation suggestions, unit test categories are also available in the completion list.
By default, suggestions of basic completion also include items from Second basic completion. If you want to change the default behavior, use the corresponding controls on the Editor | General | Code Completion page of JetBrains Rider settings .
The list of completion suggestions is the same as that of Automatic completion.
Place the caret at the position where you're going to type your code.
Press .
Select a suggestion from the list and press Enter or start typing the initial letters of the identifier or its CamelHumps abbreviation to narrow down the list of suggestions.
When you use code completion over existing code items, you can either insert the selected completion suggestion before the existing item by pressing or replace the existing identifier with the selected suggestion by pressing . If necessary, you can change the default shortcuts on the Keymap page of JetBrains Rider settings (look for the Choose Lookup Item and Choose Lookup Item Replace actions) .
When you select items in completion lists using keyboard, the selection will jump to the first item after the last item and vice versa. You can disable this behavior by clearing Cyclic scrolling in list on the Appearance and Behavior | Appearance page of JetBrains Rider settings .
When choosing a method call from the completion list, by default JetBrains Rider automatically inserts a pair of parentheses ( )
and sets the caret between them. You can change this behavior with the Automatically insert parenthesis after completion option on the Editor | General | Code Completion page of JetBrains Rider settings .
Note that you can type the opening parenthesis (
instead of Tab or Enter when a method is selected in the completion list. In this case the pair of parentheses will be inserted regardless of this option.
tip
When a completion list is open, you can press or to close it and move the caret down or up in the editor.
You may want some types or namespaces not to be suggested, for example, if you have something similar to a system type in your solution, say MyFramework.MyCollections.List
, but you are not actually using it. To exclude such items from the suggestions, add them to the Exclude from import and completion list on the Editor | General | Auto Import page of JetBrains Rider settings .
The format of the entries is Fully.Qualified.Name
, Fully.Qualified.Name.Prefix*
, or *Fully.Qualified.Name.Suffix
. Generic types are specified as List`1
.
You can access code completion settings right from the completion popup — click at the bottom of the popup and select Code Completion Settings.
You can use the following examples to get an idea of how basic completion works with various code items:
Commonly used names for fields and variables are suggested depending on their type. After entering the type of variable, press . The look-up list displays the suggested names:
data:image/s3,"s3://crabby-images/4d6ec/4d6ec12a434b0acd7ea42221e53819ffe36b1b6f" alt="JetBrains Rider: Suggesting type-based variable names in code completion JetBrains Rider: Suggesting type-based variable names in code completion"
If you enter a variable name prefix, JetBrains Rider will append it to each suggested name:
data:image/s3,"s3://crabby-images/bcb27/bcb270bfe5a8325f62121a6ebc395aa0a132dd9e" alt="JetBrains Rider: Suggesting type-based variable names in code completion JetBrains Rider: Suggesting type-based variable names in code completion"
You can specify a prefix and/or a suffix for all new variable names on the Editor | Code Style | C# page of JetBrains Rider settings . If you do that, completion items will be modified accordingly:
data:image/s3,"s3://crabby-images/6bea8/6bea8469ed23311c0bf130dd505042082f8d2ecc" alt="JetBrains Rider: Suggesting type-based variable names in code completion JetBrains Rider: Suggesting type-based variable names in code completion"
data:image/s3,"s3://crabby-images/cc581/cc581bdbedc29cf683b79fa3d8476b38db3a3098" alt="JetBrains Rider: Suggesting members of a class in code completion JetBrains Rider: Suggesting members of a class in code completion"
data:image/s3,"s3://crabby-images/ba550/ba5505338cb8f4f8d9ca5a36ac67b9f0a63321ea" alt="JetBrains Rider: Suggesting visible types in code completion JetBrains Rider: Suggesting visible types in code completion"
data:image/s3,"s3://crabby-images/1a9a9/1a9a931cba24c3b5509b173066da5411e2c08ef3" alt="JetBrains Rider: Suggesting C# keywords in code completion JetBrains Rider: Suggesting C# keywords in code completion"
data:image/s3,"s3://crabby-images/5c154/5c154ad3084cba65e52b4046750d91a382894170" alt="JetBrains Rider: Suggesting 'this' keyword for static methods in static classes JetBrains Rider: Suggesting 'this' keyword for static methods in static classes"
data:image/s3,"s3://crabby-images/e2cd3/e2cd30a5f6913c53ca1ad2de553f5e277a470297" alt="JetBrains Rider: Completion for enum members JetBrains Rider: Completion for enum members"
data:image/s3,"s3://crabby-images/e32ea/e32ead43440fa6b7b62d1b7eae25d5c72d0ee8f2" alt="JetBrains Rider: Completion for enum members JetBrains Rider: Completion for enum members"
data:image/s3,"s3://crabby-images/81bb1/81bb165fcc33daf9f641240f85dabdc775745ed6" alt="JetBrains Rider: Using CamelHumps in code completion JetBrains Rider: Using CamelHumps in code completion"
Early used names of data types and their members are suggested, even if they are not declared anywhere in the code and cannot be resolved.
data:image/s3,"s3://crabby-images/9198f/9198f7614083202fe209f1f2d286a6b2a35840fc" alt="JetBrains Rider: Completion for unresolved symbols JetBrains Rider: Completion for unresolved symbols"
data:image/s3,"s3://crabby-images/c3fd1/c3fd1f29c65c1552ad10c00e1d5eba5b484071fb" alt="JetBrains Rider: Completion for argument names JetBrains Rider: Completion for argument names"
data:image/s3,"s3://crabby-images/47090/47090b26ee4ba9328cb60843bb8446a44b8defd9" alt="JetBrains Rider: Suggesting members of a dynamic type JetBrains Rider: Suggesting members of a dynamic type"
When you type partial class
, names of partial classes in the current scope are added to the suggestion list, thus helping you to quickly create new parts of existing partial classes.
data:image/s3,"s3://crabby-images/47ba6/47ba67cdd828537ad6481e6fc722a78c12aa54fe" alt="Suggestions for existing partial classes in JetBrains Rider code completion Suggestions for existing partial classes in JetBrains Rider code completion"
If code completion is invoked on a void
-returning expression, the suggestion list displays a special hint, which helps you understand that no calls can be made at that point. Accepting this void item will just add a semicolon if it was not added before:
data:image/s3,"s3://crabby-images/4d7a1/4d7a1824d3b957a4e1a825cd2b609670a28e22cd" alt="JetBrains Rider: void expression hint in code completion JetBrains Rider: void expression hint in code completion"