KDevelop4/Manual/Customizing KDevelop: Difference between revisions

From KDE UserBase Wiki
m (fix typo)
 
(8 intermediate revisions by 4 users not shown)
Line 35: Line 35:
Two that have been found to be very useful to change are to set <menuchoice>Align</menuchoice> to the <keycap>Tab</keycap> key (many people don't usually enter tabs by hand and rather prefer if the editor chooses the layout of code; with the changed shortcut, hitting <keycap>Tab</keycap> makes '''KDevelop''' indent/outdent/align the code). The second one is putting <menuchoice>Toggle Breakpoint</menuchoice> on <keycap>Ctrl + B</keycap> since this is quite a frequent operation.
Two that have been found to be very useful to change are to set <menuchoice>Align</menuchoice> to the <keycap>Tab</keycap> key (many people don't usually enter tabs by hand and rather prefer if the editor chooses the layout of code; with the changed shortcut, hitting <keycap>Tab</keycap> makes '''KDevelop''' indent/outdent/align the code). The second one is putting <menuchoice>Toggle Breakpoint</menuchoice> on <keycap>Ctrl + B</keycap> since this is quite a frequent operation.


=== Customizing code auto-completion === <!--T:14-->


<!--T:12-->
<!--T:15-->
{{Prevnext2
Code completion is discussed in [[KDevelop4/Manual/Working_with_source_code#Auto-completion|this manual's section on writing source code]]. In '''KDevelop''', it comes from two sources: the editor, and the parse engine. The editor ('''Kate''') is a component of the larger KDE environment and offers auto-completion based on words it has already seen in other parts of the same document. Such auto-completions can be identified in the tooltip by the icon that precedes it:
| prevpage=Special:MyLanguage/KDevelop4/Manual/Working_with_version_control_systems | nextpage=Special:MyLanguage/KDevelop4/Manual/Appendix A: Building KDevelop from Sources
| prevtext=Working with version control systems | nexttext=Appendix A: Building KDevelop from Sources
| index=Special:MyLanguage/KDevelop4/Manual | indextext=Back to menu
}}


<!--T:13-->
<!--T:16-->
[[Category:Development]]
[[Image:kdevelop-20.png|thumb|500px|center]]
</translate>


=== Customizing code auto-completion ===
<!--T:17-->
The editor's code completion can be customized via <menuchoice>Settings -> Configure Editor -> Editing -> Auto Completion</menuchoice>. In particular, you can select how many characters you need to type in a word before auto-completion kicks in.


Code completion is discussed in [[KDevelop4/Manual/Working_with_source_code#Auto-completion|this manual's section on writing source code]]. In '''KDevelop''', it comes from two sources: the editor, and the parse engine. The editor ('''Kate''') is a component of the larger KDE environment and offers auto-completion based on words it has already seen in other parts of the same document. Such auto-completions can be identified in the tooltip by the icon that precedes it:
<!--T:18-->
On the other hand, '''KDevelop's''' own auto-completion is much more powerful as it takes into account semantic information about the context. For example, it knows which member functions to offer when you type <code>object.</code>, etc., as shown here:


[[Image:kdevelop-20.png|thumb|450px|center]]
<!--T:19-->
 
[[Image:kdevelop-42.png|thumb|500px|center]]
The editor's code completion can be customized via <menuchoice>Settings -> Configure Editor -> Editing -> Auto Completion</menuchoice>. In particular, you can select how many characters you need to type in a word before auto-completion kicks in.


On the other hand, '''KDevelop''''s own auto-completion is much more powerful as it takes into account semantic information about the context. For example, it knows which member functions to offer when you type <code>object.</code>, etc. This context information comes from various language support plugins, which  
<!--T:20-->
This context information comes from various language support plugins, which  
can be used after a given file has been saved (so it can check the  
can be used after a given file has been saved (so it can check the  
filetype and use the correct language support).
filetype and use the correct language support).
'''KDevelop''''s completion is set to appear as you type, right away, pretty  
'''KDevelop's''' completion is set to appear as you type, right away, pretty  
much everywhere that it could possibly complete something. This is  
much everywhere that it could possibly complete something. This is  
configurable in <enuchoice>Settings -> Configure KDevelop -> Language Support</menuchoice>. If it isn't already set (as it should, by default),
configurable in <menuchoice>Settings -> Configure KDevelop -> Language Support</menuchoice>. If it isn't already set (as it should, by default),
make sure <menuchoice>Enable Automatic Invocation</menuchoice> is set.
make sure <menuchoice>Enable Automatic Invocation</menuchoice> is set.


<!--T:21-->
'''KDevelop''' has two ways to show a completion: <menuchoice>Minimal Automatic  
'''KDevelop''' has two ways to show a completion: <menuchoice>Minimal Automatic  
Completion</menuchoice> shows just the basic information in completion tooltips (i.e. the namespace, class, function, or variable name). This will look similar to Kate completion (except for the icons).
Completion</menuchoice> shows just the basic information in completion tooltips (i.e. the namespace, class, function, or variable name). This will look similar to '''Kate''' completion (except for the icons).
On the other hand, <menuchoice>Full completion</menuchoice> will additionally show the type for each entry,  
On the other hand, <menuchoice>Full completion</menuchoice> will additionally show the type for each entry,  
and in the case of functions, also the arguments they take. Also,  
and in the case of functions, also the arguments they take. Also,  
if you are curently filling in the arguments to a function, full  
if you are currently filling in the arguments to a function, full  
completion will have an additional info-box above the cursor that will  
completion will have an additional info-box above the cursor that will  
show you the current argument you are working on.
show you the current argument you are working on.
KDevelop's code completion should also bring-to-top and highlight in  
'''KDevelop's''' code completion should also bring-to-top and highlight in  
green any completion items that match the currently expected type in  
green any completion items that match the currently expected type in  
both minimal and full completion, known as "best-matches".
both minimal and full completion, known as "best-matches".


<!--T:22-->
The three possible choices for the completion level in the configuration dialog are:
The three possible choices for the completion level in the configuration dialog are:
<!--T:23-->
* <menuchoice>Always minimal completion</menuchoice>: Never show "Full Completion"
* <menuchoice>Always minimal completion</menuchoice>: Never show "Full Completion"
* <menuchoice>Minimal automatic completion</menuchoice>: Only show "Full Completion" when auto-completion has been triggered manually (i.e., whenever you hit <code>Ctrl+Space</code>)
 
<!--T:24-->
* <menuchoice>Minimal automatic completion</menuchoice>: Only show "Full Completion" when auto-completion has been triggered manually (i.e., whenever you hit <keycap>Ctrl+Space</keycap>)
 
<!--T:25-->
* <menuchoice>Always full completion</menuchoice>: Always show "Full Completion"
* <menuchoice>Always full completion</menuchoice>: Always show "Full Completion"
<!--T:12-->
{{Prevnext2
| prevpage=Special:MyLanguage/KDevelop4/Manual/Working_with_version_control_systems | nextpage=Special:MyLanguage/KDevelop4/Manual/Appendix A: Building KDevelop from Sources
| prevtext=Working with version control systems | nexttext=Appendix A: Building KDevelop from Sources
| index=Special:MyLanguage/KDevelop4/Manual | indextext=Back to menu
}}
<!--T:13-->
[[Category:Development]]
</translate>

Latest revision as of 18:09, 25 August 2011

Other languages:

Customizing KDevelop

There are times when you want to change the default appearance or behavior of KDevelop, for example because you are used to different keyboard shortcuts or because your project requires a different indenting style for source code. In the following sections, we briefly discuss the various ways how KDevelop can be customized for these needs.

Customizing the editor

There are a number of useful things one can configure in and around KDevelop's built-in editor. Of more universal use is to switch on line numbering using the menu entry Editor -> View -> Show line numbers, making it easier to match compiler error messages or debug messages with locations in the code. In the same submenu you may also want to switch on the Icon border - a column to the left of your code in which KDevelop will show icons such as whether there is a breakpoint on the current line.

Customizing code indentation

Many of us like code formatted in a particular way. Many projects also enforce a particular indentation style. Neither may match KDevelop's default indentation style. However, this can be customized: Go to the Settings -> Customize KDevelop menu item, then click on Source Formatter on the left. You can choose one of the predefined indentation styles that are widely in use, or define your own one by adding a new style and then editing it. There may not be a way to exactly re-create the style in which your project's sources have been indented in the past, but you can come close by using the settings for a new style; an example is shown in the two pictures below.

Note

With KDevelop 4.2.2, you can create a new style for a particular mimetype (e.g. for C++ header files) but this style does not show up among the list of possible styles for other mimetypes (e.g. for C++ source files) although it would of course be useful to use the same style for both kinds of files. You will therefore have to define the style twice, once for header and once for source files. This has been reported as KDevelop bug 272335.


Customizing keyboard shortcuts

KDevelop has an almost boundless list of keyboard shortcuts (some of them are listed in the "Useful keyboard shortcuts sections" of several chapters in this manual) that can be changed to your taste through the menu Settings -> Configure Shortcuts. At the top of the dialog you can enter a searchword and it only shows those commands that match; you can then edit which key combination is bound to this command.

Two that have been found to be very useful to change are to set Align to the Tab key (many people don't usually enter tabs by hand and rather prefer if the editor chooses the layout of code; with the changed shortcut, hitting Tab makes KDevelop indent/outdent/align the code). The second one is putting Toggle Breakpoint on Ctrl + B since this is quite a frequent operation.

Customizing code auto-completion

Code completion is discussed in this manual's section on writing source code. In KDevelop, it comes from two sources: the editor, and the parse engine. The editor (Kate) is a component of the larger KDE environment and offers auto-completion based on words it has already seen in other parts of the same document. Such auto-completions can be identified in the tooltip by the icon that precedes it:

The editor's code completion can be customized via Settings -> Configure Editor -> Editing -> Auto Completion. In particular, you can select how many characters you need to type in a word before auto-completion kicks in.

On the other hand, KDevelop's own auto-completion is much more powerful as it takes into account semantic information about the context. For example, it knows which member functions to offer when you type object., etc., as shown here:

This context information comes from various language support plugins, which can be used after a given file has been saved (so it can check the filetype and use the correct language support). KDevelop's completion is set to appear as you type, right away, pretty much everywhere that it could possibly complete something. This is configurable in Settings -> Configure KDevelop -> Language Support. If it isn't already set (as it should, by default), make sure Enable Automatic Invocation is set.

KDevelop has two ways to show a completion: Minimal Automatic Completion shows just the basic information in completion tooltips (i.e. the namespace, class, function, or variable name). This will look similar to Kate completion (except for the icons). On the other hand, Full completion will additionally show the type for each entry, and in the case of functions, also the arguments they take. Also, if you are currently filling in the arguments to a function, full completion will have an additional info-box above the cursor that will show you the current argument you are working on. KDevelop's code completion should also bring-to-top and highlight in green any completion items that match the currently expected type in both minimal and full completion, known as "best-matches".

The three possible choices for the completion level in the configuration dialog are:

  • Always minimal completion: Never show "Full Completion"
  • Minimal automatic completion: Only show "Full Completion" when auto-completion has been triggered manually (i.e., whenever you hit Ctrl+Space)
  • Always full completion: Always show "Full Completion"