Difference between revisions of "Lazarus IDE Tools/de"

From Lazarus wiki
Jump to navigationJump to search
m (→‎Code-Schablonen: findet sich unter Werkzeuge -> Vorlagen)
 
(72 intermediate revisions by 12 users not shown)
Line 1: Line 1:
 
{{Lazarus IDE Tools}}
 
{{Lazarus IDE Tools}}
  
==Überblick==
+
== Überblick ==
Die IDE verwendet eine Bibliothek von pascal source parsing and editing tools, genannt die "codetools". Diese Werkzeuge bieten Features wie find declaration, code completion, extraction, moving inserting und beautifying pascal sources. Diese Funktionen sparen ihnen eine Menge Zeit und doppelte Arbeit. Sie sind anpassbar und jedes Feature ist verfügbar mittels Tastenkombinationen (siehe Editor Optionen).
+
Die IDE verwendet eine Bibliothek von Werkzeugen zum Analysieren und Bearbeiten von Pascal-Quelltexten, genannt die "CodeTools". Diese Werkzeuge bieten Features wie Deklaration finden, Codevervollständigung, Isolation, Verschieben, Einfügen und Verschönern von Pascal-Quelltext. Diese Funktionen sparen Ihnen eine Menge Zeit und doppelte Arbeit. Sie können angepasst werden. Jedes Feature ist über Tastenkombinationen verfügbar (siehe Editoreinstellungen).
  
Weil sie ausschließlich an den Quellen arbeiten und FPC, Delphi und Kylix Code verstehen, benötigen sie keine kompilierten Units oder einen installierten Borland Compiler. Sie können Delphi und FPC Code zur selben Zeit bearbeiten. Sie können sogar mit verschiedenen Delphi und FPC Versionen zur selben Zeit arbeiten. Dies macht die Protierung von Delphi Code sehr viel einfacher.
+
Weil sie ausschließlich mit Quelltexten arbeiten und den Code von FPC, Delphi und Kylix verstehen, benötigen sie weder kompilierte Units noch einen installierten Borland Compiler. Sie können Delphi- und FPC-Code zur gleichen Zeit bearbeiten. Sie können sogar mit verschiedenen Delphi- und FPC-Versionen zur selben Zeit arbeiten. Dies macht die Portierung von Delphi-Code sehr viel einfacher.
  
==Übersichtstabelle der IDE Tastenkombinationen==
+
== Übersichtstabelle der IDE-Tastenkombinationen ==
 
{|
 
{|
 
|-
 
|-
| Declaration Jumping || Ctrl+Click (jump to declaration of type or variable)
+
| [[Lazarus_IDE_Tools/de#Find Declaration|Declaration Jumping]] || {{keypress|Strg}}+Klick (springt zur Deklaration eines Typs oder einer Variablen)
 
|-
 
|-
| Method Jumping || Ctrl+Shift+Up (toggle between definition and body)
+
| [[Lazarus_IDE_Tools/de#Methodenspringen|Methodenspringen]] || {{keypress|Strg}}+{{keypress|Shift}}+{{keypress|Up}} (schaltet zwischen Definition und Rumpf einer Prozedur/Methode um)
 
|-
 
|-
| Code Templates || Ctrl+J
+
| [[Lazarus_IDE_Tools/de#Code-Schablonen|Code-Schablonen]] || {{keypress|Strg}}+{{keypress|J}}
 
|-
 
|-
| Code Completion (Class Completion)   || Ctrl+Shift+C
+
| [[Lazarus_IDE_Tools/de#Synchronbearbeitung|Synchronbearbeitung]] || {{keypress|Strg}}+{{keypress|J}} (bei ausgewähltem Text)
 
|-
 
|-
| Identifier Completion || Ctrl+Space
+
| [[Lazarus_IDE_Tools/de#Codevervollständigung|Codevervollständigung]] (Klassenvervollständigung) || {{keypress|Strg}}+{{keypress|Shift}}+{{keypress|C}}
 +
|-
 +
| [[Lazarus_IDE_Tools/de#Bezeichner-Vervollständigung|Bezeichner-Vervollständigung]] || {{keypress|Strg}}+{{keypress|Space}}
 +
|-
 +
| [[Lazarus_IDE_Tools/de#Wortvervollständigung|Wortvervollständigung]] || {{keypress|Strg}}+{{keypress|W}}
 +
|-
 +
| [[Lazarus_IDE_Tools/de#Parameter-Hinweise|Parameter-Hinweise]] || {{keypress|Strg}}+{{keypress|Shift}}+{{keypress|Space}}
 +
|-
 +
| [[Lazarus_IDE_Tools/de#Inkrementelle Suche|Inkrementelle Suche]] || {{keypress|Strg}}+{{keypress|E}}
 +
|-
 +
| [[Lazarus_IDE_Tools/de#Bezeichner umbenennen|Bezeichner umbenennen]] || {{keypress|Strg}}+{{keypress|Shift}}+{{keypress|E}}
 
|}
 
|}
  
==Method Jumping==
+
==Methodenspringen==
To jump between a procedure body (begin..end) and the procedure definition (procedure Name;) use Ctrl+Shift+Up.
+
Um zwischen einem Prozedurrumpf (begin..end) und der Prozedurdefinition (procedure Name;) zu springen, verwenden Sie {{keypress|Strg}}+{{keypress|Shift}}+{{keypress|Nach oben}}.
 +
 
 +
Zum Beispiel:
 +
<syntaxhighlight lang=pascal>interface
  
For example:
+
procedure DoSomething; // Prozedurdefinition
interface
+
 
+
implementation
procedure DoSomething; // procedure definition
+
 
 +
procedure DoSomething; // Prozedurrumpf
 +
begin
 +
end;</syntaxhighlight>
 +
 
 +
Wenn der Cursor auf dem Prozedurrumpf ist und Sie {{keypress|Strg}}+{{keypress|Shift}}+{{keypress|Nach oben}} drücken, dann wird der Kursor zur Definition springen. Erneutes Drücken von {{keypress|Strg}}+{{keypress|Shift}}+{{keypress|Nach oben}} wird wieder zum Rumpf springen, nach 'begin'.
 +
 
 +
Dies funktioniert ebenfalls zwischen Methoden (Prozeduren in Klassen).
 +
 
 +
Hinweise:
 +
Methodenspringen springt zur selben Prozedur mit dem selben Namen und Parameterliste. Wenn es keine bestimmte Prozedur gibt, springt es zum besten Kandidaten und positioniert den Kursor auf dem ersten Unterschied. (Für Delphianer: Delphi kann dies nicht tun).
 +
 
 +
Zum Beispiel eine Prozedur mit verschiedenen Parametertypen:
 +
<syntaxhighlight lang=pascal>interface
 +
 
 +
procedure DoSomething(p: char); // Prozedurdefinition
 +
 
 +
implementation
 
    
 
    
implementation
+
procedure DoSomething(p: string); // Prozedurrumpf
 
+
begin
procedure DoSomething; // procedure body
+
end;</syntaxhighlight>
begin
+
 
end;
+
Das Springen von der Definition zum Rumpf wird den Kursor auf dem 'string' Schlüsselwort positionieren. Dies kann verwendet werden für das Umbenennen von Methoden und/oder das Ändern von Parametern.  
If the cursor is on the procedure body and you press Ctrl+Shift+Up, the cursor will jump to the definition. Pressing Ctrl+Shift+Up again will jump to the body, after 'begin'.
+
 
 +
Zum Beispiel:<br>
 +
Sie benannten 'DoSomething' in 'MakeIt' um:
 +
<syntaxhighlight lang=pascal>interface
  
This works between methods (procedures in classes) as well.
+
procedure MakeIt; // Prozedurdefinition
  
Hints:
+
implementation
'Method Jumping' jumps to the same procedure with the same name and parameter list. If there is no exact procedure, it jumps to the best candidate and positions the cursor on the first difference. (For Delphians: Delphi can not do this).
 
  
For example a procedure with different parameter types:
+
procedure DoSomething; // Prozedurrumpf
interface
+
begin
+
end;</syntaxhighlight>
procedure DoSomething(p: char); // procedure definition
 
 
implementation
 
 
 
procedure DoSomething(p: string); // procedure body
 
begin
 
end;
 
Jumping from the definition to the body will position the cursor at the 'string' keyword. This can be used for renaming methods and/or changing the parameters.
 
  
For example:<br>
+
Dann springen Sie von MakeIt zum Rumpf. Die IDE sucht nach einem passenden Rumpf, findet keinen, und sucht daher nach einem Kandidaten. Weil Sie nur eine Prozedur umbenannt haben, gibt es exakt einen Rumpf ohne Definition (DoSomething) und daher wird sie zu DoSomething springen und den Kursor rechts neben 'DoSomething' positionieren. Dann können Sie sie dort auch umbenennen. Das funktioniert ebenfalls für Parameter.
You renamed 'DoSomething' to 'MakeIt':
 
interface
 
 
procedure MakeIt; // procedure definition
 
 
implementation
 
 
procedure DoSomething; // procedure body
 
begin
 
end;
 
Then you jump from MakeIt to the body. The IDE searches for a fitting body, does not find one, and hence searches for a candidate. Since you renamed only one procedure there is exactly one body without definition (DoSomething) and so it will jump to DoSomething and position the cursor right on 'DoSomething'. Then you can simply rename it there too. This works for parameters as well.
 
  
==Include Dateien==
+
== Include-Dateien ==
Include Dateien sind Dateien, die mit der ($I filename) oder ($INCLUDE filename) Compiler Direktive in die Quellen eingefügt werden. Lazarus und FPC verwenden eine Menge von diesen Dingen um Redundanz zu reduzieren und unlesbare ($IFDEF) Konstrukte zu vermeiden um verschiedene Plattformen zu unterstützen.
+
Include-Dateien sind Dateien, die mit der ($I Dateiname) oder ($INCLUDE Dateiname) Compilerdirektive in die Quellen eingefügt werden. Lazarus und FPC verwenden oft Include-Dateien, um Redundanz zu reduzieren und unlesbare ($IFDEF) Konstrukte zu vermeiden um verschiedene Plattformen zu unterstützen.
  
Im Gegensatz zu Delphi bietet die Lazarus IDE volle Unterstützung für include Dateien. Sie können zum Beispiel von der Methode in der .pas Datei zum Methodenrumpf in der include Datei springen. Alle codetools wie code completion berücksichtigen include Dateien als spezielle bounds.
+
Im Gegensatz zu Delphi bietet die Lazarus IDE volle Unterstützung für Include-Dateien. Sie können zum Beispiel von der Methode in der .pas Datei zum Methodenrumpf in der Include-Datei springen. Alle CodeTools wie ''Codevervollständigung'' berücksichtigen Include-Dateien als spezielle Schranken.
 
   
 
   
Zum Beispiel: Wenn code completion einen neuen Methodenrumpf hinzufügt hinter anderen Methodenrümpfen, it keeps them both in the same file. This way you can put whole class implementations in include files, wie es die LCL für nahezu alle Bedienelemente tut.
+
Zum Beispiel: Wenn die ''Codevervollständigung'' einen neuen Methodenrumpf hinzufügt hinter anderen Methodenrümpfen, behält sie beide in der selben Datei. Auf diese Weise können Sie ganze Klassenimplementierungen in Include-Dateien verwenden, wie es die LCL für nahezu alle Bedienelemente tut.
  
 
Aber es gibt eine Anfängerfalle:
 
Aber es gibt eine Anfängerfalle:
Wenn sie eine include Datei zum ersten mal öffnen und method jumping oder find declaration ausprobieren, erhalten sie eine Fehlermeldung. Die IDE weiß nicht, zu welcher Unit die include Datei gehört. Sie müssen die Unit zuerst öffnen.
+
Wenn Sie eine Include-Datei zum ersten Mal öffnen und ''method jumping'' oder ''find declaration'' ausprobieren, erhalten Sie eine Fehlermeldung. Die IDE weiß nicht, zu welcher Unit die Include-Datei gehört. Sie müssen die Unit zuerst öffnen.
  
As soon as the IDE parses the unit, it will parse the include directives there and the IDE will remember this relationship. It saves this information on exit and on project save to ~/.lazarus/includelinks.xml. The next time you open this include file and jump or do a find declaration, the IDE will internally open the unit and the jump will work.
+
Sobald die IDE die Unit analysiert, wird sie die Include-Direktive dort finden und die IDE wird sich an diese Beziehung erinnern. Sie wird diese Informationen beim Beenden (oder beim Speichern des Projekts) speichern in der Datei ~/.lazarus/includelinks.xml. Wenn Sie diese Include-Datei das nächste Mal öffnen und eine 'find declaration' durchführen, wird die IDE die Unit intern öffnen und das Springen wird funktionieren.
 +
Sie können die IDE auch direkt hinweisen mit
 +
<syntaxhighlight lang=pascal>{%mainunit yourunit.pas}</syntaxhighlight>
 +
am Anfang Ihrer yourinclude.inc.
  
Dieser Mechanismus hat natürlich Grenzen. Einige include Dateien sind zweimal oder mehrfach einbezogen. Zum Beispiel: lcl/include/winapih.inc.
+
Dieser Mechanismus hat natürlich Grenzen. Einige Include-Dateien sind zweimal oder mehrfach einbezogen. Zum Beispiel: lcl/include/winapih.inc.
  
Jumping from the procedure/method definitions in this include file to the bodies depends on your last actions. If you worked on lcl/lclintf.pp the IDE will jump to winapi.inc. If you worked on lcl/interfacebase.pp, then it will jump to lcl/include/interfacebase.inc (or one of the other include files). If you are working on both, then you can get confused. ;)
+
Das Springen von den Prozedur-/Methodendefinitionen in diese Include-Datei zu den Rümpfen hängt von Ihren letzten Aktionen ab. Wenn Sie an lcl/lclintf.pp gearbeitet haben dann wird die IDE zu winapi.inc springen. Wenn Sie an lcl/interfacebase.pp gearbeitet haben, dann wird sie zu lcl/include/interfacebase.inc springen (oder einer der anderen Include-Dateien). Wenn Sie an beiden arbeiten, dann können Sie verwirrt werden. ;)
  
==Code Templates==
+
==Code-Schablonen==
Code Templates konvertieren einen Bezeichner in einen Text oder code fragment.
+
Code-Schablonen konvertieren einen Bezeichner in einen Text oder Code-Fragment.
  
Die Code Templates Vorgabetastenkombination ist Ctrl+J. Sie können einen Bezeichner eintippen, Ctrl+J drücken und der Bezeichner wird durch den Text ersetzt, der für den Bezeichner definiert ist. Code Templates können definiert werden in Einstellungen -> CodeTemplates.
+
Die Code-Schablonen Vorgabetastenkombination ist {{keypress|Strg}}+{{keypress|J}}. Sie können einen Bezeichner eintippen, {{keypress|Strg}}+{{keypress|J}} drücken und der Bezeichner wird durch den Text ersetzt, der für den Bezeichner definiert ist. Code-Schablonen können definiert werden in Werkzeuge -> Vorlagen.
  
 
Beispiel:
 
Beispiel:
Schreiben sie den Bezeichner 'classf', hinterlassen den Cursor rechts hinter dem 'f' und drücken Ctrl+J. Das 'classf' wird ersetzt durch
+
Schreiben Sie den Bezeichner 'classf', lassen Sie den Kursor hinter dem 'f' stehen und drücken Sie {{keypress|Strg}}+{{keypress|J}}. Das 'classf' wird ersetzt durch
T = class(T)
+
<syntaxhighlight lang=pascal>T = class(T)
private
+
private
+
 
public
+
public
  constructor Create;
+
  constructor Create;
  destructor Destroy; override;
+
  destructor Destroy; override;
end;
+
end;</syntaxhighlight>
 +
 
 
und der Cursor ist hinter dem 'T'.
 
und der Cursor ist hinter dem 'T'.
Sie können die Liste der Vorlagen abrufen in dem sie den Cursor an eine freie Stelle positionieren (nicht auf einem Bezeichner) und Ctrl+J drücken. Die Liste der code templates wird auftauchen. Verwenden sie die Cursortasten oder tippen einige Buchstaben um eine auszuwählen. Return erzeugt die gewählte Vorlage und Escape schließt das pop up.
+
Sie können die Liste der Vorlagen abrufen, in dem Sie den Kursor an eine freie Stelle positionieren (nicht auf einem Bezeichner) und {{keypress|Strg}}+{{keypress|J}} drücken. Die Liste der Code-Schablonen wird auftauchen. Verwenden Sie die Kursortasten oder tippen Sie einige Buchstaben um eine auszuwählen. {{keypress|Eingabe}} erzeugt die gewählte Vorlage und {{keypress|Escape}}schließt das Popup-Fenster.
 +
 
 +
Die größten Zeitsparer sind die Schablonen 'b'+{{keypress|Strg}}+{{keypress|J}} für begin..end.
 +
 
 +
== Parameter-Hinweise ==
 +
 
 +
Parameter-Hinweise zeigen eine Hinweisbox mit den Parameter-Deklarationen für die aktuelle Parameterliste.
  
==Code Completion==
+
Zum Beispiel
Code Completion can be found in the IDE menu Edit -> Complete Code and has as standard short cut Ctrl+Shift+C.
 
  
For Delphians:
+
<syntaxhighlight lang=pascal>  Canvas.FillRect(|);</syntaxhighlight>
Delphi calls "code completion" the function showing the list of identifiers at the current source position (Ctrl+Space). Under Lazarus this is called "Identifier completion".
 
  
Code Completion combines several powerful functions. Examples:
+
Platzieren Sie den Cursor in den Klammern und drücken Sie {{keypress|Strg}}+{{keypress|Shift}}+{{keypress|Leertaste}}. Eine Hinweisbox erscheint mit den Parametern von FillRect.
* Class Completion: completes properties, adds method bodies, add private variables and private access methods
 
* Forward Procedure Completion: adds procedure bodies
 
* Event Assignment Completion: completes event assignments and adds method definition and body
 
* Variable Declaration Completion: adds local variable definitions
 
  
Which function is used, depends on the cursor position in the editor.  
+
[[Image:Parameterhints1.png]]
  
Code Completion can be found in the IDE menu Edit -> Complete Code and has as standard short cut Ctrl+Shift+C.
+
Seit Version 0.9.31 gibt es eine Schaltfläche rechts neben jeder Deklaration um fehlende Parameters einzufügen. Diese kopiert die Parameternamen aus der ausgewählten Deklaration an die Kursorposition.
 +
 
 +
[[Image:Parameterhints2.png]]
 +
 
 +
Tipp: Benutzen Sie die [[#Variable Declaration Completion|Variable Declaration Completion]] um Variablen zu deklarieren.
 +
 
 +
Beachten Sie: Der Name des Tastenkürzels ist "Code-Context anzeigen".
 +
 
 +
== Inkrementelle Suche ==
 +
 
 +
Die inkrementelle Suche ändert die Statuszeile des Quelltexteditors. Geben Sie ein paar Zeichen ein und der Editor sucht und markiert sofort alle Fundstellen im Text. Das Tastaturkürzel ist {{keypress|Strg}}+{{keypress|E}}.
 +
*Zum Beispiel: Sie drücken {{keypress|A}}, sucht und markiert alle Fundstellen von 'A'.
 +
*Dann drücken Sie {{keypress|T}} und alle Fundstellen von 'at' sind markiert usw.
 +
*Sie springen zur nächsten Fundstelle mit {{keypress|F3}} (oder {{keypress|Strg}}+{{keypress|E}} während der Suche) und zur vorigen Fundstelle mit {{keypress|Umschalt}}+{{keypress|F3}}.
 +
*{{keypress|Backspace}} entfernt das letzte Zeichen
 +
*{{keypress|Eingabe}} stoppt die Suche ohne eine neue Zeile im Editor.
 +
*Sie nehmen die letzte Suche erneut auf mit einem zweiten {{keypress|Strg}}+{{keypress|E}}, sofort nach dem Start der Suche mit {{keypress|Strg}}+{{keypress|E}}. Das gilt solange das Suchfeld noch leer ist.
 +
*Einfügen mit {{keypress|Strg}}+{{keypress|V}} hängt den Text aus der Zwischenablage an den aktuellen Suchtext an (seit Lazarus 0.9.27 r19824).
 +
 
 +
=== Hinweis: Schnelle Suche nach einem Bezeichner mit der inkrementellen Suche ===
 +
 
 +
*Stellen Sie den Textkursor auf den Bezeichner. (Wählen Sie nichts aus!)
 +
*Drücken Sie {{keypress|Strg}}+{{keypress|C}}. Der Editor wählt den Bezeichner aus und kopiert ihn in die Zwischenablage
 +
*Drücken Sie {{keypress|Strg}}+{{keypress|E}} - startet die inkrementelle Suche
 +
*Drücken Sie {{keypress|Strg}}+{{keypress|V}} - sucht nach dem Bezeichner (seit Version 0.9.27)
 +
*Mit {{keypress|F3}} und {{keypress|Umschalt}}+{{keypress|F3}} springen Sie zum nächsten/vorigen Fund.
 +
*Mit einer beliebigen Taste (beispielsweise Kursor links oder rechts) beenden Sie die Suche
 +
 
 +
==Synchronbearbeitung==
 +
 
 +
Die Synchronbearbeitung ermöglicht es Ihnen, alle Fundstellen eines Wortes gleichzeitig (synchronisiert) zu bearbeiten. Sie bearbeiten einfach das Wort an einer Stelle und gleichzeitig mit Ihren Eingaben werden auch alle anderen Fundstellen des Wortes aktualisiert.
 +
 
 +
Die Synchronbearbeitung verarbeitet alle Worte in einem ausgewählten Bereich:
 +
* Selektieren Sie einen Textblock
 +
* Drücken Sie {{keypress|Strg}}+{{keypress|J}} oder klicken Sie auf das Symbol in der Randleiste. (Das funktioniert nur, wenn Worte in der Auswahl mehr als einmal auftreten.)
 +
* Benutzen Sie die {{keypress|Tab}}-Taste, um das zu bearbeitende Wort auszuwählen (wenn einige verschiedene Wörter mehrfach auftreten).
 +
* Bearbeiten Sie das Wort.
 +
* Drücken Sie {{keypress|Esc}} zum Beenden
 +
 
 +
Sehen Sie sich [[New_IDE_features_since#Syncron-Edit|hier]] ein animiertes Beispiel an.
 +
 
 +
* Anmerkung: {{keypress|Strg}}+{{keypress|J}} wird auch beim Bearbeiten von Vorlagen benutzt. Die Bedeutung ändert sich, wenn Sie einen Text auswählen.
 +
 
 +
== Suche nächste / vorhergehende Fundstelle des Wortes ==
 +
 
 +
Die zwei Funktionen sind im Kontextmenü des Quelltexteditors zu finden
 +
 
 +
*Quelltexteditor / Kontextmenü / Suchen / Nächste Fundstelle des Wortes
 +
*Quelltexteditor / Kontextmenü / Suchen / Vorhergehende Fundstelle des Wortes
 +
 
 +
Und Sie können diesen Funktionen in den Editoreinstellungen ein Tastenkürzel zuweisen.
 +
 
 +
== Codevervollständigung ==
 +
Die Codevervollständigung ist im IDE-Menü zu finden unter Bearbeiten -> Quelltext vervollständigen und hat das Standardkürzel {{keypress|Strg|Shift|C}}.
 +
 
 +
Für Delphianer:
 +
Delphi bezeichnet mit "Codevervollständigung" die Funktion, die die Liste der Bezeichner an der aktuellen Quellenposition zeigt ({{keypress|Strg|Leertaste}}). Unter Lazarus wird dies ''Bezeichnervervollständigung'' genannt.
 +
 
 +
''Codevervollständigung'' kombiniert verschiedene mächtige Funktionen. Beispiele:
 +
* [[#Class Completion|Class Completion]]: komplettiert Eigenschaften; fügt Methodenrümpfe, private Variablen und private Zugriffsmethoden hinzu
 +
* [[#Forward Procedure Completion|Forward Procedure Completion]]: fügt Prozedurenrümpfe hinzu
 +
* [[#Event Assignment Completion|Event Assignment Completion]]: komplettiert Ereigniszuweisungen; fügt Methodendefinition und -rumpf hinzu
 +
* [[#Variable Declaration Completion|Variable Declaration Completion]]: fügt lokale Variablendefinitionen hinzu
 +
* [[#Reversed Class Completion|Reversed Class Completion]]: fügt Methoden-Deklarationen für Methodenrümpfe hinzu
 +
* [[#Procedure Call Completion|Procedure Call Completion]]: fügt eine neue Prozedur hinzu
 +
* [[#Reversed Procedure Completion|Reversed procedure completion]]: fügt Deklarationen für Prozedur-/Funktionsrümpfe hinzu
 +
 
 +
Welche Funktion genutzt wird, hängt von der Kursorposition im Editor ab und wird unten beschrieben.
 +
 
 +
Die Codevervollständigung ist im IDE-Menü zu finden unter Bearbeiten -> Quelltext vervollständigen und hat das Standardkürzel {{keypress|Strg|Shift|C}}.  
  
 
===Class Completion===
 
===Class Completion===
  
Das mächtigste code completion Feature ist "Class Completion". Sie schreiben eine class, fügen die Methoden und Eigenschaften hinzu und Code Completion wird die Methodenrümpfe hinzufügen, die Eigenschaftszugriff Methoden/Variablen und die private Variablen.  
+
Das mächtigste Codevervollständigungs-Feature ist ''Class Completion''. Sie schreiben eine Klasse, fügen die Methoden und Eigenschaften hinzu und Codevervollständigung wird die Methodenrümpfe hinzufügen, die Methoden/Variablen des Eigenschaftszugriffs und die private Variablen.  
 +
 
 +
Zum Beispiel: Erzeugen Sie eine Klasse (siehe Code-Schablonen, um einige Tipparbeit zu sparen):
 +
 
 +
<syntaxhighlight lang=pascal>TExample = class(TObject)
 +
public
 +
  constructor Create;
 +
  destructor Destroy; override;
 +
end;</syntaxhighlight>
 +
 
 +
Positionieren Sie den Kursor irgendwo in der Klasse und drücken Sie {{keypress|Strg|Shift|C}}. Dies wird die fehlenden Methodenrümpfe erzeugen und den Kursor zu dem ersten erzeugten Methodenrumpf bewegen, so dass Sie jetzt mit dem Schreiben des Klassencodes beginnen können:
 +
 
 +
<syntaxhighlight lang=pascal>{ TExample }
 +
 
 +
constructor TExample.Create;
 +
begin
 +
  |
 +
end;
 +
 
 +
destructor TExample.Destroy;
 +
begin
 +
  inherited Destroy;
 +
end;</syntaxhighlight>
  
Zum Beispiel: Erzeugen sie eine class (siehe Code Templates um einige Tipparbeit zu sparen):  
+
Anmerkung: Das '|' ist der Kursor und nicht hinzugefügt.
  
TExample = class(TObject)
+
Hinweis: Sie können zwischen einer Methode und ihrem Rumpf springen mit {{keypress|Strg|Shift|Nach oben}}.  
public
 
  constructor Create;
 
  destructor Destroy; override;
 
end;
 
Positionieren sie den Cursor irgendwo in der class und drücken Ctrl+Shift+C. Dies wird die fehlenden Methodenrümpfe erzeugen und den Cursor zu dem ersten erzeugten Methodenrumpf bewegen, so daß sie jetzt mit dem Schreiben des class Codes beginnen können:
 
  
{ TExample }
+
Sie können sehen, dass die IDE auch den 'inherited Destroy' Aufruf hinzugefügt hat. Dies passiert, wenn es ein 'override' Schlüsselwort in der Klassendefinition gibt.  
 
constructor TExample.Create;
 
begin
 
  |
 
end;
 
 
destructor TExample.Destroy;
 
begin
 
  inherited Destroy;
 
end;
 
Anmerkung: Das '|' ist der Cursor und nicht hinzugefügt.  
 
  
Hinweis: Sie können zwischen einer Methode und ihrem Rumpf springen mit Ctrl+Shift+Up.
+
Jetzt fügen Sie eine Methode DoSomething hinzu:
  
Sie können sehen, daß die IDE auch den 'inherited Destroy' Aufruf hinzugefügt hat. Dies wird getan, wenn es ein 'override' Schlüsselwort in der class Definition gibt.
+
<syntaxhighlight lang=pascal>TExample = class(TObject)
 +
public
 +
  constructor Create;
 +
  procedure DoSomething(i: integer);
 +
  destructor Destroy; override;
 +
end;</syntaxhighlight>
  
Jetzt fügen sie eine Methode DoSomething hinzu:  
+
Dann drücken Sie {{keypress|Strg|Shift|C}} und die IDE wird hinzufügen:  
  
TExample = class(TObject)
+
<syntaxhighlight lang=pascal>procedure TExample.DoSomething(i: integer);
public
+
begin
  constructor Create;
+
  |
  procedure DoSomething(i: integer);
+
end;</syntaxhighlight>
  destructor Destroy; override;
 
end;
 
Dann drücken sie Ctrl+Shift+C und die IDE wird hinzufügen
 
  
procedure TExample.DoSomething(i: integer);
+
Sie sehen, der neue Methodenrumpf wurde zwischen Create und Destroy eingefügt, exakt wie in der Klassendefinition. So behalten auch die Methodenrümpfe die gleiche logische Ordnung bei (wie von Ihnen festgelegt). Sie legen die Einfügerichtlinien fest in Einstellungen -> Codetools Einstellungen -> Quelltexterzeugung.  
begin
 
  |
 
end;
 
Sie können sehen, daß der neue Methodenrumpf eingefügt wurde zwischen Create und Destroy, exakt wie in der class Definition. This way the bodies keep the same logical ordering as you define. You can define the insertion policy in Environment > Codetools Options -> Code Creation.  
 
  
 
'''Complete Properties'''<br>
 
'''Complete Properties'''<br>
Fügen sie eine Eigenschaft AnInteger hinzu:
+
Fügen Sie eine Eigenschaft 'AnInteger' hinzu:
TExample = class(TObject)
+
<syntaxhighlight lang=pascal>TExample = class(TObject)
public
+
public
  constructor Create;
+
  constructor Create;
  procedure DoSomething(i: integer);
+
  procedure DoSomething(i: integer);
  destructor Destroy; override;
+
  destructor Destroy; override;
  property AnInteger: Integer;
+
  property AnInteger: Integer;
end;
+
end;</syntaxhighlight>
Drücken sie Ctrl+Shift+C und sie werden erhalten:
 
procedure TExample.SetAnInteger(const AValue: integer);
 
begin
 
  |if FAnInteger=AValue then exit;
 
  FAnInteger:=AValue;
 
end;
 
The code completion has added a Write access modifier and added some common code.
 
Jump to the class with Ctrl+Shift+Up to see the new class:
 
TExample = class(TObject)
 
private
 
  FAnInteger: integer;
 
  procedure SetAnInteger(const AValue: integer);
 
public
 
  constructor Create;
 
  procedure DoSomething(i: integer);
 
  destructor Destroy; override;
 
  property AnInteger: integer read FAnInteger write SetAnInteger;
 
end;
 
The property was extended by a Read and Write access modifier. The class got the new section 'private' with a Variable 'FAnInteger' and the method 'SetAnInteger'.
 
It is a common Delphi style rule to prepend private variables with an 'F' and the write method with a 'Set'. If you don't like that, you can change this in Environment > Codetools Options -> Code Creation.
 
  
Creating a read only property:
+
Drücken Sie {{keypress|Ctrl|Shift|C}} und Sie erhalten:
property PropName: PropType read;
+
<syntaxhighlight lang=pascal>procedure TExample.SetAnInteger(const AValue: integer);
Will be expanded to
+
begin
property PropName: PropType read FPropName;
+
  |if FAnInteger=AValue then exit;
Creating a write only property:
+
   FAnInteger:=AValue;
   property PropName: PropType write;
+
end;</syntaxhighlight>
Will be expanded to
 
property PropName: PropType write SetPropName;
 
Creating a read only property with a Read method:
 
property PropName: PropType read GetPropName;
 
Will be kept and a GetPropName function will be added:
 
function GetpropName: PropType;
 
Creating a property with a stored modifier:
 
property PropName: PropType stored;
 
Will be expanded to
 
property PropName: PropType read FPropName write SetPropName stored PropNameIsStored;
 
Because stored is used for streaming read and write modifiers are automatically added as well.
 
  
Hint:
+
Die Codevervollständigung hat den Schreibzugriff geändert und den üblichen Code ergänzt.
Identifier completion also recognizes incomplete properties and will suggest the default names. For example:
+
Springen Sie mit {{keypress|Strg|Shift|Nach oben}} zur Klasse, um die neue Klasse ganz zu sehen:
property PropName: PropType read |;
+
<syntaxhighlight lang=pascal>TExample = class(TObject)
Place the cursor one space behind the 'read' keyword and press Ctrl+Space for the identifier completion. It will present you the variable 'FPropName' and the procedure 'SetPropName'.
+
private
 +
  FAnInteger: integer;
 +
  procedure SetAnInteger(const AValue: integer);
 +
public
 +
  constructor Create;
 +
  procedure DoSomething(i: integer);
 +
  destructor Destroy; override;
 +
  property AnInteger: integer read FAnInteger write SetAnInteger;
 +
end;</syntaxhighlight>
 +
 
 +
Die Eigenschaft wurde um einen Lese- und Schreibzugriff erweitert. Die Klasse erhielt den neuen Abschnitt 'private' mit einer Variable 'FAnInteger' und der Methode 'SetAnInteger'.
 +
Es ist eine allgemein übliche Delphi-Stil-Regel, den privaten Variablen ein 'F' und der write-Methode ein 'Set' voranzustellen. Wenn Sie das nicht mögen, können Sie es ändern unter Einstellungen -> Codetools Einstellungen -> Quelltexterzeugung.
 +
 
 +
Erzeugen einer Eigenschaft 'read only':
 +
<syntaxhighlight lang=pascal>property PropName: PropType read;</syntaxhighlight>
 +
wird erweitert zu
 +
<syntaxhighlight lang=pascal>property PropName: PropType read FPropName;</syntaxhighlight>
 +
Erzeugen einer Eigenschaft 'write only':
 +
<syntaxhighlight lang=pascal>property PropName: PropType write;</syntaxhighlight>
 +
wird erweitert zu
 +
<syntaxhighlight lang=pascal>property PropName: PropType write SetPropName;</syntaxhighlight>
 +
Erzeugen einer Eigenschaft 'read only' mit einer Read-Methode:
 +
<syntaxhighlight lang=pascal>property PropName: PropType read GetPropName;</syntaxhighlight>
 +
wird beibehalten und eine Funktion 'GetPropName' wird angefügt:
 +
<syntaxhighlight lang=pascal>function GetpropName: PropType;</syntaxhighlight>
 +
Erzeugen einer Eigenschaft mit einem stored-Modifizierer:
 +
<syntaxhighlight lang=pascal>property PropName: PropType stored;</syntaxhighlight>
 +
wird erweitert zu
 +
<syntaxhighlight lang=pascal>property PropName: PropType read FPropName write SetPropName stored PropNameIsStored;</syntaxhighlight>
 +
Weil 'stored' für das Streaming benutzt wird, werden automatisch auch die read- und write-Modifizierer angefügt.
 +
 
 +
Hinweis:
 +
Die ''Bezeichnervervollständigung'' erkennt auch unvollständige Eigenschaften und wird die Standardnamen vorschlagen. Zum Beispiel:
 +
<syntaxhighlight lang=pascal>property PropName: PropType read |;</syntaxhighlight>
 +
Platzieren Sie den Kursor eine Leerstelle hinter dem 'read'-Schlüsselwort und drücken Strg+Space für die Bezeichnervervollständigung. Diese wird Ihnen die Variable 'FPropName' und die Prozedur 'SetPropName' präsentieren.
  
 
===Forward Procedure Completion===
 
===Forward Procedure Completion===
"Forward Procedure Completion" is part of the Code Completion and adds missing procedure bodies. It is invoked, when the cursor is on a forward defined procedure.
+
Die ''Forward Procedure Completion'' ist ein Teil der Codevervollständigung und fügt fehlende Prozedurrümpfe hinzu. Sie wird aufgerufen, wenn der Kursor auf einer vorwärts definierten Prozedur ist.
 +
 
 +
Zum Beispiel:
 +
Fügen Sie eine neue Prozedur zum Interface-Abschnitt hinzu:
 +
<syntaxhighlight lang=pascal>procedure DoSomething;</syntaxhighlight>
 +
Platzieren Sie den Kursor darauf und drücken Sie {{keypress|Strg|Shift|C}} für Codevervollständigung. Es wird im Implementation-Abschnitt erzeugen:
 +
<syntaxhighlight lang=pascal>procedure DoSomething;
 +
begin
 +
  |
 +
end;</syntaxhighlight>
 +
 
 +
Hinweis: Sie können zwischen einer Prozedurdefinition und ihrem Rumpf springen mit {{keypress|Strg|Shift|Nach oben}}.
 +
 
 +
Der neue Prozedurrumpf wird vor den Klassenmethoden eingefügt. Wenn es bereits einige Prozeduren im Interface-Abschnitt gibt, versucht die IDE die Ordnung einzuhalten. Zum Beispiel:
 +
<syntaxhighlight lang=pascal>procedure Proc1;
 +
procedure Proc2; // neue Prozedur
 +
procedure Proc3;</syntaxhighlight>
  
For example:
+
Wenn die Rümpfe von Proc1 und Proc3 bereits existieren, dann wird der Proc2 Rumpf zwischen den Rümpfen von Proc1 und Proc3 eingefügt. Dieses Verhalten kann eingestellt werden in Einstellungen -> CodeTools Einstellungen -> Quelltexterzeugung.
Add a new procedure to the interface section:
 
procedure DoSomething;
 
Place the cursor on it and press Ctrl+Shift+C for code completion. It will create in the implementation section:
 
procedure DoSomething;
 
begin
 
  |
 
end;
 
Hint: You can jump between a procedure definition and its body with Ctrl+Shift+Up.
 
  
The new procedure body will be added in front of the class methods. If there are already some procedures in the interface the IDE tries to keep the ordering. For example:
+
Mehrere Prozeduren:
  procedure Proc1;
+
<syntaxhighlight lang=pascal>procedure Proc1_Old; // Rumpf existiert
  procedure Proc2; // new proc
+
procedure Proc2_New; // Rumpf existiert nicht
  procedure Proc3;
+
procedure Proc3_New; //  "
If the bodies of Proc1 and Proc3 already exists, then the Proc2 body will be inserted between the bodies of Proc1 and Proc3. This behaviour can be setup in Environment > Codetools Options -> Code Creation.
+
procedure Proc4_New; //  "
 +
procedure Proc5_Old; // Rumpf existiert</syntaxhighlight>
  
Multiple procedures:
+
Die Codevervollständigung wird alle 3 Prozedurrümpfe hinzufügen (Proc2_New, Proc3_New, Proc4_New).
procedure Proc1_Old; // body exists
 
procedure Proc2_New; // body does not exists
 
procedure Proc3_New; //  "
 
procedure Proc4_New; //  "
 
procedure Proc5_Old; // body exists
 
Code Completion will add all 3 procedure bodies (Proc2_New, Proc3_New, Proc4_New).
 
  
Why calling it "Forward Procedure Completion"?
+
Warum wird das ''Forward Procedure Completion'' genannt?
  
Because it does not only work for procedures defined in the interface, but for procedures with the "forward" modifier as well.
+
Weil es nicht nur für Prozeduren funktioniert, die im Interface definiert sind, sondern auch für Prozeduren mit dem "forward"-Bezeichner. Und weil die CodeTools Prozeduren im Interface so behandeln als hätten sie einen impliziten "forward"-Bezeichner.
  
 
===Event Assignment Completion===
 
===Event Assignment Completion===
"Event Assignment Completion" is part of the Code Completion and completes a single Event:=| statement. It is invoked, when the cursor is behind an assignment to an event.
+
Die "Event Assignment Completion" ist ein Teil der ''Codevervollständigung'' und komplettiert eine einzelne Ereignis:=| Anweisung. Sie wird aufgerufen, wenn der Kursor hinter einer Ereigniszuweisung steht.
 +
 
 +
Zum Beispiel:
 +
In einer Methode, sagen wir dem FormCreate Ereignis, fügen wir eine Zeile 'OnPaint:=' hinzu:
 +
<syntaxhighlight lang=pascal>procedure TForm1.Form1Create(Sender: TObject);
 +
begin
 +
  OnPaint:=|
 +
end;</syntaxhighlight>
  
For example:
+
Das '|' ist der Kursor und sollte nicht eingegeben werden.
In a method, say the FormCreate event, add a line 'OnPaint:=':
+
Dann drücken sie Strg+Shift+C für die ''Codevervollständigung''. Die Anweisung wird komplettiert zu
procedure TForm1.Form1Create(Sender: TObject);
+
<syntaxhighlight lang=pascal>OnPaint:=@Form1Paint;</syntaxhighlight>
begin
+
Eine neue Methode Form1Paint wird zur Klasse TForm1 hinzugefügt. Dann wird die ''class completion'' gestartet und Sie erhalten:
  OnPaint:=|
+
<syntaxhighlight lang=pascal>procedure TForm1.Form1Paint(Sender: TObject);
end;
+
begin
The '|' is the cursor and should not be typed.
+
  |
Then press Ctrl+Shift+C for code completion. The statement will be completed to
+
end;</syntaxhighlight>
OnPaint:=@Form1Paint;
+
Das funktioniert wie das Hinzufügen von Methoden im Objektinspektor.
A new method Form1Paint will be added to the TForm1 class. Then class completion is started and you get:
 
procedure TForm1.Form1Paint(Sender: TObject);
 
begin
 
  |
 
end;
 
This works just like adding methods in the object inspector.
 
  
Note:<br>
+
Anmerkung:<br>
You must place the cursor behind the ':=' assignment operator. If you place the cursor on the identifier (e.g. OnPaint) code completion will invoke "Local Variable Completion", which fails, because OnPaint is already defined.
+
Sie müssen den Kursor hinter dem ':=' Zuweisungsoperator platzieren. Wenn Sie den Kursor auf dem Bezeichner platzieren (z.B. OnPaint) wird die Codevervollständigung die "Local Variable Completion" aufrufen, was fehlschlägt, weil OnPaint bereits definiert ist.
  
Hint:<br>
+
Hinweis:<br>
You can define the new method name by yourself. For example:
+
Sie können den neuen Methodennamen selbst definieren. Zum Beispiel:
  OnPaint:=@ThePaintMethod;
+
<syntaxhighlight lang=pascal>OnPaint:=@ThePaintMethod;</syntaxhighlight>
  
 
===Variable Declaration Completion===
 
===Variable Declaration Completion===
"Variable Declaration Completion" is part of the Code Completion and adds a local variable definition for a Identifier:=Term; statement. It is invoked, when the cursor is on the identifier of an assignment or a parameter.
+
Die "Variable Declaration Completion" ist ein Teil der Codevervollständigung und fügt eine lokale Variablendefinition zu einer Identifier:=Term; Anweisung hinzu. Sie wird aufgerufen, wenn der Kursor auf dem Bezeichner in einer Zuweisung oder einem Parameter ist.
  
For example:
+
Zum Beispiel:
procedure TForm1.Form1Create(Sender: TObject);
+
<syntaxhighlight lang=pascal>procedure TForm1.Form1Create(Sender: TObject);
begin
+
begin
  i:=3;
+
  i:=3;
end;
+
end;</syntaxhighlight>
Place the cursor on the 'i' or just behind it. Then press Ctrl+Shift+C for code completion and you will get:
+
Platzieren Sie den Kursor auf dem 'i' oder genau dahinter. Dann drücken Sie {{keypress|Strg|Shift|C}} für die Codevervollständigung und Sie erhalten:
procedure TForm1.Form1Create(Sender: TObject);
+
<syntaxhighlight lang=pascal>procedure TForm1.Form1Create(Sender: TObject);
var
+
var
  i: Integer;
+
  i: Integer;
begin
+
begin
  i:=3;
+
  i:=3;
end;
+
end;</syntaxhighlight>
The codetools first checks, if the identifier 'i' is already defined and if not it will add the declaration 'var i: integer;'. The type of the identifier is guessed from the term right to the assignment ':=' operator. Numbers like the 3 defaults to Integer.
 
  
Another example:
+
Die CodeTools prüfen zuerst, ob der Bezeichner 'i' bereits definiert ist und wenn nicht werden sie die Deklaration 'var i: integer;' hinzufügen. Der Typ des Bezeichners wird erraten vom Ausdruck rechts des ':=' Zuweisungsoperators. Zahlen wie die 3 sind mit Integer vorbelegt.
type
+
 
 +
Ein anderes Beispiel:
 +
<syntaxhighlight lang=pascal>type
 
   TWhere = (Behind, Middle, InFront);
 
   TWhere = (Behind, Middle, InFront);
 
   
 
   
Line 296: Line 394:
 
   begin
 
   begin
 
     for Where:=Low(a) to High(a) do writeln(a[Where]);
 
     for Where:=Low(a) to High(a) do writeln(a[Where]);
   end;
+
   end;</syntaxhighlight>
Place the cursor on 'Where' and press Ctrl+Shift+C for code completion. You get:
+
 
  procedure TForm1.Form1Create(Sender: TObject);
+
Platzieren Sie den Kursor auf 'Where' und drücken Sie {{keypress|Strg|Shift|C}} für die Codevervollständigung. Sie erhalten:
 +
<syntaxhighlight lang=pascal>  procedure TForm1.Form1Create(Sender: TObject);
 
   var
 
   var
 
     a: array[TWhere] of char;
 
     a: array[TWhere] of char;
Line 304: Line 403:
 
   begin
 
   begin
 
     for Where:=Low(a) to High(a) do writeln(a[Where]);
 
     for Where:=Low(a) to High(a) do writeln(a[Where]);
   end;
+
   end;</syntaxhighlight>
  
Since 0.9.11 Lazarus also completes parameters. For example
+
Seit Version 0.9.11 komplettiert Lazarus auch Parameter. Zum Beispiel
  procedure TForm1.FormPaint(Sender: TObject);
+
<syntaxhighlight lang=pascal>  procedure TForm1.FormPaint(Sender: TObject);
 
   begin
 
   begin
 
     with Canvas do begin
 
     with Canvas do begin
 
       Line(x1,y1,x2,y2);
 
       Line(x1,y1,x2,y2);
 
     end;
 
     end;
   end;
+
   end;</syntaxhighlight>
Place the cursor on 'x1' and press Ctrl+Shift+C for code completion. You get:
+
 
  procedure TForm1.FormPaint(Sender: TObject);
+
Platzieren Sie den Kursor auf 'x1' und drücken Sie {{keypress|Strg|Shift|C}} für die Codevervollständigung. Sie erhalten:
 +
<syntaxhighlight lang=pascal>  procedure TForm1.FormPaint(Sender: TObject);
 
   var
 
   var
 
     x1: integer;
 
     x1: integer;
Line 321: Line 421:
 
       Line(x1,y1,x2,y2);
 
       Line(x1,y1,x2,y2);
 
     end;
 
     end;
 +
  end;</syntaxhighlight>
 +
 +
===Procedure Call Completion===
 +
Die Codevervollständigung kann auch eine neue Prozedur aus dem Prozeduraufruf selbst erzeugen.
 +
 +
Angenommen, Sie haben gerade die Anweisung "DoSomething(Width);" geschrieben
 +
<syntaxhighlight lang=pascal>procedure SomeProcedure;
 +
var
 +
  Width: integer;
 +
begin
 +
  Width:=3;
 +
  DoSomething(Width);
 +
end;</syntaxhighlight>
 +
 +
Platzieren Sie den Kursor über dem Bezeichner "DoSomething" und drücken Sie {{keypress|Strg|Shift|C}}. Sie erhalten:
 +
 +
<syntaxhighlight lang=pascal>procedure DoSomething(aWidth: LongInt);
 +
begin
 +
 +
end;
 +
 +
procedure SomeProcedure;
 +
var
 +
  Width: integer;
 +
begin
 +
  Width:=3;
 +
  DoSomething(Width);
 +
end;</syntaxhighlight>
 +
 +
Es werden derzeit noch keine Funktionen oder Methoden erzeugt.
 +
 +
===Reversed Class Completion===
 +
 +
"Reversed Class Completion" ist ein Teil der '''Codevervollständigung''' und fügt eine private Methodendeklaration zum aktuellen Methodenrumpf hinzu. Sie wird aufgerufen, wenn der Cursor in einem Methodenrumpf ist, der noch nicht in der Klasse definiert wurde.
 +
Dieses Feature ist seit Lazarus 0.9.21 verfügbar.
 +
 +
Zum Beispiel:
 +
<syntaxhighlight lang=pascal>  procedure TForm1.DoSomething(Sender: TObject);
 +
  begin
 +
  end;</syntaxhighlight>
 +
 +
Die Methode DoSomething ist noch nicht in TForm1 deklariert. Drücken Sie {{keypress|Strg|Shift|C}} und die IDE wird "procedure DoSomething(Sender: TObject);" zu den privaten Methoden von TForm1 hinzufügen.
 +
 +
Für Delphianer:
 +
Die Klassenergänzung arbeitet unter Lazarus immer in einer Richtung: Von dem Klasseninterface zur Implementation oder rückwärts/umgekehrt von der Klassenimplementation zum Interface. Delphi ruft immer beide Richtungen auf. Das Delphi-Verfahren hat den Nachteil, dass bei einem Rechtschreibfehler leicht eine neue Methodenvorlage erzeugt wird ohne Benachrichtigung.
 +
 +
===Kommentare und Codevervollständigung===
 +
Die Codevervollständigung versucht die Kommentare dort zu behalten, wo sie hingehören.
 +
Zum Beispiel:
 +
<syntaxhighlight lang=pascal>  FList: TList; // list of TComponent
 +
  FInt: integer;</syntaxhighlight>
 +
Wenn eine neue Variable zwischen FList und FInt eingesetzt wird, dann wird der Kommentar in der FList Zeile beibehalten. Das selbe gilt für
 +
<syntaxhighlight lang=pascal>  FList: TList; { list of TComponent
 +
    Dies ist ein Kommentar über mehrere Zeilen, beginnend
 +
    in der FList-Zeile. Die CodeTools nehmen an, er gehöre
 +
    zu der FList-Zeile und brechen diese Beziehung nicht
 +
    auf. Der Code wird hinter dem Kommentar eingefügt. }
 +
  FInt: integer;</syntaxhighlight>
 +
Wenn der Kommentar in der nächsten Zeile startet, dann wird er behandelt, wie wenn er zum nachfolgenden Code gehört. Zum Beispiel:
 +
<syntaxhighlight lang=pascal>  FList: TList; // list of TComponent
 +
    { Dieser Kommentar gehört zur nachfolgenden Anweisung.
 +
      Neuer Code wird oberhalb des Kommentars eingefügt und
 +
      hinter dem Kommentar der FList-Zeile. }
 +
  FInt: integer;</syntaxhighlight>
 +
 +
===Method update===
 +
Normalerweise fügt die Klassenergänzung alle fehlenden Methodenrümpfe ein. (Seit Version 0.9.27) Falls sich aber genau eine Methode zwischen Klassendeklaration und Rümpfen unterscheidet, dann wird der Methodenrumpf aktualisiert. Zum Beispiel: Sie haben eine Methode ''DoSomething''.
 +
<syntaxhighlight lang=pascal>  public
 +
    procedure DoSomething;
 
   end;
 
   end;
  
===Comments and Code Completion===
+
procedure TForm.DoSomething;
Code completion tries to keep comments where they belong.  
+
begin
For example:
+
end;</syntaxhighlight>
  FList: TList; // list of TComponent
+
 
  FInt: integer;
+
Fügen Sie jetzt einen Parameter hinzu:
When inserting a new variable between FList and FInt, the comment is kept in the FList line. Same is true for
+
 
  FList: TList; { list of TComponent
+
<syntaxhighlight lang=pascal>  public
    This is a comment over several lines, starting
+
     procedure DoSomething(i: integer);
    in the FList line, so codetools assumes it belongs
+
   end;</syntaxhighlight>
     to the FLIst line and will not break this
+
 
    relationship. Code is inserted behind the comment. }
+
und rufen Sie die Codevervollständigung auf mit ({{keypress|Strg|Shift|C}}). Der Methodenrumpf wird aktualisiert und der neue Parameter wird kopiert:
  FInt: integer;
+
 
If the comment starts in the next line:
+
<syntaxhighlight lang=pascal>procedure TForm.DoSomething(i: integer);
   FList: TList; // list of TComponent
+
begin
    { This comment belongs to the statement below.  
+
end;</syntaxhighlight>
      New code is inserted above this comment and
 
      behind the comment of the FList line. }
 
  FInt: integer;
 
  
 
==Refactoring==
 
==Refactoring==
Line 346: Line 512:
 
===Invert Assignments===
 
===Invert Assignments===
  
;Abstract: : "Invert Assignments" takes some selected pascal statements and inverts all assignments from this code. This tool is usefull for transforming a "save" code to a "load" one and inverse operation.
+
;Kurz gefasst: "Invert Assignments" nimmt einige ausgewählte Pascal-Anweisungen und invertiert alle Zuweisungen aus diesem Code. Dieses Werkzeug ist hilfreich für das Umwandeln eines "Speicher"-Codes in einen "Lade"-Code und umgekehrt.
 +
 
 +
Beispiel:<br>
 +
<syntaxhighlight lang=pascal>procedure DoSomething;
 +
begin
 +
  AValueStudio:= BValueStudio;
 +
  AValueAppartment :=BValueAppartment;
 +
  AValueHouse:=BValueHouse;
 +
end;</syntaxhighlight>
  
Example:<br>
+
Wählen Sie die Zeilen mit den Zuweisungen aus (zwischen begin und end) und führen Sie "Invert Assignments" aus. Alle Zuweisungen werden invertiert und die Einrückung wird automatisch hinzugefügt. Zum Beispiel:
procedure DoSomething;
 
begin
 
  AValueStudio:= BValueStudio;
 
  AValueAppartment :=BValueAppartment;
 
  AValueHouse:=BValueHouse;
 
end;
 
Select the lines with assignments (between begin and end) and do Invert Assignments. All assignments will be inverted and identation will be add automatically. For example:
 
  
Result:
+
Resultat:
procedure DoSomething;
+
<syntaxhighlight lang=pascal>procedure DoSomething;
begin
+
begin
  BValueStudio    := AValueStudio;
+
  BValueStudio    := AValueStudio;
  BValueAppartment := AValueAppartment;
+
  BValueAppartment := AValueAppartment;
  BValueHouse      := AValueHouse;
+
  BValueHouse      := AValueHouse;
end;
+
end;</syntaxhighlight>
  
===Extract Procedure===
+
=== Enclose Selection ===
;Abstract: : "Extract Procedure" takes some selected pascal statements and creates a new procedure/method from this code. This tool is useful to split big procedures or to easily create a new procedure from some code.
+
Wählen Sie einigen Text aus und rufen Sie die Vervollständigung auf. In dem aufscheinenden Dialog können Sie auswählen, ob der selektierte Text in '''try..finally''' oder einen der vielen anderen üblichen Blöcke eingeschlossen werden soll.
  
Basic example:<br>
+
===Bezeichner umbenennen===
procedure DoSomething;
+
Stellen Sie den Kursor auf einen Bezeichner und rufen Sie die Vervollständigung auf. Es erscheint ein Dialog, wo Sie den Suchbereich und den neuen Namen festlegen können.  
begin
+
* Es werden alle Vorkommen umbenannt und zwar nur jene, die tatsächlich diese Deklaration verwenden. Das bedeutet, dass nicht automatisch alle Deklarationen mit dem selben Namen umbenannt werden.  
  CallSomething;
+
* Und es wird zuerst auf Namenskonflikte überprüft.
end;
+
* Beschränkungen: Das funktioniert nur mit Pascal-Quellen, benennt keine Dateinamen um und bearbeitet weder lfm/lrs-Dateien noch lazdoc-Dateien.
Select the line "CallSomething;" and do Extract Proc. A dialog pop ups and
 
you can select the type and name of the procedure to create. For example:
 
procedure, "NewProc". Result:
 
procedure NewProc;
 
begin
 
  CallSomething;
 
end;
 
 
procedure DoSomething;
 
begin
 
  NewProc;
 
end;
 
You can see, that the new procedure "NewProc" was created with the selection
 
as body and the old code was replaced by a call.
 
  
Local Variables and Parameters:<br>
+
===Find Identifier References===
"Extract Proc" scans for used variables and automatically creates the
+
Stellen Sie den Kursor auf einen Bezeichner und rufen Sie die Vervollständigung auf. Es erscheint ein Dialog, wo Sie den Suchbereich festlegen können. Die IDE sucht dann nach allen Vorkommen und nur solchen, die tatsächlich diese Deklaration verwenden. Das bedeutet, dass nicht andere Deklarationen mit dem selben Namen angezeigt werden.
parameter list and local variables. Example:
 
procedure TForm1.DoSomething(var Erni, Bert: integer);
 
var
 
  i: Integer; // Comment
 
begin
 
  Erni:=Erni+Bert;
 
  for i:=Erni to 5 do begin
 
  |
 
  end;
 
end;
 
Select the for loop and create a new Procedure "NewProc". The local variable i is only used in the selection, so it will be moved to the new procedure. Erni is also used in the remaining code, so it will become a parameter.
 
  
Result:<br>
+
=== Show abstract methods ===
procedure NewProc(const Erni: integer);
+
Dieses Merkmal listet und ergänzt automatisch virtuelle, abstrakte Methoden, die noch implementiert werden müssen.
var
+
Stellen Sie den Kursor auf eine Klassendeklaration und rufen Sie die Vervollständigung auf. Falls es fehlende abstrakte Methoden gibt, werden diese in einem Dialog aufgelistet. Wählen Sie die zu implementierende Methode aus und die IDE erzeugt eine Methodenschablone.
  i: Integer; // Comment
 
begin
 
  for i:=Erni to 5 do begin
 
  |
 
  end;
 
end;
 
 
procedure TForm1.DoSomething(var Erni, Bert: integer);
 
begin
 
  Erni:=Erni+Bert;
 
  NewProc(Erni);
 
end;
 
  
You can see "i" was moved to the new procedure (Note: including its comment) and Erni.
+
===Prozedur extrahieren===
  
Limitations:<br>
+
Siehe [[IDE_Window:_Extract_Procedure|Prozedur extrahieren]]
Pascal is a very powerful language, so don't expect it will work with every code. Current limits/ToDos:
 
* check if selection bounds on statement bounds
 
* "with" statements
 
  
 
==Find Declaration==
 
==Find Declaration==
Position the cursor on an identifier and do 'Find Declaration'. Then it will search the declaration of this identifier, open the file and jump to it.
+
Positionieren Sie den Kursor auf einem Bezeichner und starten Sie ''Find Declaration''. Das wird die Deklaration dieses Bezeichners suchen, die Datei öffnen und zu ihr springen. Falls der Kursor bereits auf der Deklaration ist, erfolgt ein Sprung zur vorherigen Deklaration mit dem selben Name. Dies erlaubt es, Neudefinitionen und Overrides zu finden.
 +
 
 +
Jede ''find declaration'' setzt einen Sprungpunkt. Das bedeutet, Sie springen mit ''find declaration'' zur Deklaration und einfach zurück mit Suche -> Zurückspringen.
 +
 
 +
Es gibt einige Unterschiede zu Delphi:
 +
Die CodeTools arbeiten mit den Quellen, den normalen Pascal-Regeln folgend, anstelle der Verwendung der Compiler-Ausgaben. Der Compiler liefert den finalen Typ zurück. Die CodeTools sehen die Quellen und alle Schritte dazwischen. Zum Beispiel:
 +
 
 +
Die ''Visible'' Eigenschaft wird zuerst in TControl (controls.pp) definiert, dann neu definiert in TCustomForm und letztlich in TForm neu definiert.
 +
Das Aufrufen von ''find declaration'' auf Visible wird Sie zuerst zu Visible in TForm bringen. Dann können Sie ''Find Declaration'' erneut aufrufen um zu Visible in TCustomForm zu springen und nochmals, um zu Visible in TControl zu springen.
 +
 
 +
Das selbe gilt für Typen wie TColor.
 +
Für den Compiler ist es einfach ein 'longint'. Aber in den Quellen ist es definiert als
 +
<syntaxhighlight lang=pascal>TGraphicsColor = -$7FFFFFFF-1..$7FFFFFFF;
 +
TColor = TGraphicsColor;</syntaxhighlight>
 +
 
 +
Und das selbe für '''forward defined classes''':
 +
Zum Beispiel gibt es in TControl eine private Variable
 +
<syntaxhighlight lang=pascal>FHostDockSite: TWinControl;</syntaxhighlight>
 +
Find declaration auf TWinControl springt zur forward definition
 +
<syntaxhighlight lang=pascal>TWinControl = class;</syntaxhighlight>
 +
Und ein erneuter Aufruf springt zur realen Implementierung
 +
<syntaxhighlight lang=pascal>TWinControl = class(TControl)</syntaxhighlight>
 +
Auf diese Weise können Sie jeden Bezeichner aufspüren und jede Überladung finden.
 +
 
 +
'''Tipps:'''
 +
* Sie können zurück springen mit {{keypress|Strg|H}}.
 +
* Sie können alle besuchten Orte anzeigen/erreichen mittels Menü: Ansicht / Sprungliste anzeigen ...
 +
* Mit einer 5-Tasten-Maus können Sie die beiden Extratasten dazu verwenden, vorwärts/rückwärts zu den besuchten Orten zu gehen
 +
:(Sie können die Tastenbelegung ändern mit Menü: Einstellungen / Maus / Erweitert
 +
Siehe auch:  [[IDE_Window:_EditorMouseOptionsAdvanced#Change_History_Jumps_for_3_button_Mouse_.28follow_back_the_.22Source_Link.22_trail.29|advanced mouse options]])
 +
 
 +
==Bezeichner-Vervollständigung==
 +
Die "Bezeichner-Vervollständigung" wird aufgerufen mittels {{keypress|Strg|space}}. Sie zeigt alle Bezeichner im Suchbereich. Zum Beipiel:
 +
 
 +
<syntaxhighlight lang=pascal>procedure TForm1.FormCreate(Sender: TObject);
 +
begin
 +
  |
 +
end;</syntaxhighlight>
 +
 
 +
Stellen Sie den Kursor zwischen ''begin'' und ''end'' und drücken Sie {{keypress|Strg|space}}. Die IDE/CodeTools untersuchen nun den gesamten erreichbaren Code und präsentieren Ihnen eine Liste aller gefundenen Bezeichner. Die CodeTools speichern die Ergebnisse zwischen, sodass ein neuerlicher Aufruf sehr viel schneller verläuft.
 +
 
 +
'''Anmerkung für Delphianer:''' Delphi nennt das ''Code completion''.
 +
 
 +
Einige Bezeichner wie 'Write', 'ReadLn', 'Low', 'SetLength', 'Self', 'Result', 'Copy' sind in den Compiler eingebaut und nirgends sonst im Quellcode definiert. Die Bezeichner-Vervollständigung hat ebenfalls viele solche Dinge eingebaut. Falls Ihnen eines fehlt, schreiben Sie einfach einen Wunsch ("feature request") im Bug-Tracker.
 +
 
 +
Die ''Bezeichner-Vervollständigung'' ergänzt nicht alle '''Schlüsselwörter'''. So können Sie sie nicht dazu benutzen 'repe' zu 'repeat' zu ergänzen. Nehmen Sie dafür {{keypress|Strg|W}} [[#Word Completion|Wortvervollstandigung]] oder {{keypress|Strg|J}} [[#Code Templates|Code-Schablonen]]. Seit Version 0.9.27 ergänzt die ''Bezeichner-Vervollständigung'' einige Schlüsselwörter.
 +
 
 +
Die Bezeichner-Vervollständigung zeigt sogar solche Bezeichner an, die inkompatibel sind.
 +
 
 +
===Präfix===
 +
Sie könne die Bezeichner-Vervollständigung mitten in einem Wort starten. Dann werden die Buchstaben links als Präfix genommen. Zum Beispiel:
 +
 
 +
<syntaxhighlight lang=pascal>procedure TForm1.FormCreate(Sender: TObject);
 +
begin
 +
  Ca|ption
 +
end;</syntaxhighlight>
 +
 
 +
Die Suchliste zeigt Ihnen dann nur diejenigen Bezeichner an, die mit 'Ca' beginnen.
 +
 
 +
===Tasten===
 +
 
 +
* Buchstabe oder Ziffer: füge das Zeichen hinzu im Quelltexteditor und im aktuellen Präfix. Dadurch wird die Liste aktualisiert.
 +
* Backspace: entfernt das letzte Zeichen aus dem Quelltexteditor und dem Präfix. Aktualisiert die Liste.
 +
* Eingabe: ersetzt das ganze Wort am Kursor mit dem ausgewählten Bezeichner und schließt das Popup-Fenster.
 +
* Umschalt+Eingabe: wie ''Eingabe'', aber ersetzt nur das Präfix (linker Teil) des Wortes am Kursor.
 +
* Nach oben/Nach unten: bewegt die Auswahl
 +
* Escape: schließt das Popup-Fenster ohne Änderungen
 +
* Tab: ergänzt das Präfix zur nächsten Auswahl. Zum Beispiel: Das aktuelle Präfix ist 'But' und die Bezeichner-Vervollständigung zeigt nur 'Button1' und 'Button1Click'. Durch Drücken von ''Tab'' wird das Präfix zu 'Button1' ergänzt.
 +
* Else: wie ''Eingabe'' und fügt das Zeichen zum Quelltexteditor hinzu
 +
 
 +
===Methoden===
 +
 
 +
Wenn der Kursor in einer Klassendefinition steht und Sie die Vervollständigung aufrufen für eine in einer Vorfahren-Klasse definierten Methode, dann werden automatisch die Parameter und das Schlüsselwort 'override' angefügt. Zum Beispiel:
 +
 
 +
<syntaxhighlight lang=pascal>TMainForm = class(TForm)
 +
protected
 +
  mous|
 +
end;</syntaxhighlight>
 +
 
 +
Die Vervollständigung von '''MouseDown''' ergibt:
 +
 
 +
<syntaxhighlight lang=pascal>TMainForm = class(TForm)
 +
protected
 +
  procedure MouseDown(Button: TMouseButton; Shift: TShiftState; X,
 +
        Y: Integer); override;
 +
end;</syntaxhighlight>
 +
 
 +
===Eigenschaften===
 +
 
 +
<syntaxhighlight lang=pascal>property MyInt: integer read |;</syntaxhighlight>
 +
 
 +
Die Bezeichner-Vervollständigung zeigt Ihnen '''FMyInt''' und '''GetMyInt'''.
 +
 
 +
<syntaxhighlight lang=pascal>property MyInt: integer write |;</syntaxhighlight>
 +
 
 +
Die Bezeichner-Vervollständigung zeigt Ihnen '''FMyInt''' und '''SetMyInt'''.
 +
 
 +
===Uses-Abschnitt / Unitnamen===
 +
 
 +
In Uses-Abschnitten zeigt die Bezeichner-Vervollständigung die Dateinamen aller Units im Suchpfad. Diese werden immer in Kleinbuchstaben angezeigt (z.B. '''avl_tree'''), weil die meisten Units ohnehin kleinbuchstabige Dateinamen haben. Bei der Vervollständigung wird aber die "niedliche" Schreibweise für Dateinamen eingesetzt (z.B. '''AVL_Tree''').
 +
 
 +
===Anweisungen===
 +
 
 +
<syntaxhighlight lang=pascal>procedure TMainForm.Button1Click(Sender: TObject);
 +
begin
 +
  ModalRe|;
 +
end;</syntaxhighlight>
 +
 
 +
wird zu:
 +
 
 +
<syntaxhighlight lang=pascal>procedure TMainForm.Button1Click(Sender: TObject);
 +
begin
 +
  ModalResult:=|;
 +
end;</syntaxhighlight>
 +
 
 +
==Wortvervollständigung==
 +
Die "Wortvervollständigung" wird aufgerufen mit {{keypress|Strg|W}}. Sie zeigt alle Wörter aus allen derzeit offenen Editoren und kann deshalb auch in Nicht-Pascal-Quelltexten, in Kommentaren und für Schlüsselwörter benutzt werden.
 +
 
 +
Ansonsten funktioniert sie genau gleich wie die Bezeichner-Vervollständigung.
 +
 
 +
==Zu Include-Anweisung springen==
 +
"Zu Include-Anweisung springen" im Menü 'Suchen' der IDE springt zur {$I filename} Anweisung, wo die aktuelle Include-Datei verwendet wird.
 +
 
 +
==Projekt veröffentlichen==
 +
Erzeugt eine Kopie des gesamten Projekts. Wenn Sie jemandem einfach die Quellen und Kompilereinstellungen Ihres Codes senden wollen, dann ist diese Funktion Ihr Freund.
 +
 
 +
Ein normales Projektverzeichnis enthält eine Menge an Informationen. Das meiste davon wird für eine Veröffentlichung nicht benötigt:
 +
Die .lpi Datei enthält Sessioninformationen (wie Cursorposition und Lesezeichen geschlossener Units) und das Projektverzeichnis enthält eine Menge von .ppu und .o Dateien und die ausführbare Datei.
 +
Um eine .lpi Datei zu erzeugen, die nur die Basisinformationen und nur den Quellen enthält (zusammen mit allen Unterverzeichnissen), verwenden Sie "Projekt veröffentlichen".
 +
 
 +
'''Anmerkung''': Seit Version 0.9.13 gibt es eine neue ''Projekteinstellung'' die es Ihnen erlaubt, Sessioninformationen in einer anderen Datei als der normalen .lpi Datei zu speichern. Diese neue Datei endet mit der .lps Erweiterung und enthält nur Sessioninformationen, was die .lpi Datei viel übersichtlicher macht.
 +
 
 +
In dem Dialog können Sie den Exclude- und Include-Filter einstellen, und mit dem anschließenden Kommando können Sie den Output in ein einzelnes Archiv komprimieren.
 +
 
 +
==Tipps von Kommentaren==
 +
 
 +
An verschiedenen Stellen zeigt die IDE Tipps für einen Bezeichner an. Beispielsweise, wenn Sie den Mauszeiger über einen Bezeichner im Quelltexteditor bewegen und einige Sekunden warten.
 +
Wenn die IDE einen Tipp für einen Bezeichner anzeigt, sucht sie die Deklaration und alle ihre Vorfahren und hält nach Kommentaren und fpdoc-Dateien Ausschau. Es gibt viele Kodierstile und viele Kommentierstile. Um möglichst viele der allgemein üblichen Stile zu unterstützen, benutzt die IDE folgende Heuristik:
  
Every find declaration sets a Jump Point. That means you jump with find declaration to the declaration and easily jump back with Search -> Jump back.
+
===Kommentare im Tipp angezeigt===
  
There are some differences to Delphi:
+
Kommentare vor einer Deklaration, ohne Leerzeile und nicht mit dem '''<'''-Zeichen beginnend:
The codetools work on sources following the normal pascal rules, instead of using the compiler output. The compiler returns the final type. The codetools see the sources and all steps in between. For example:
 
  
The 'Visible' property is first defined in TControl (controls.pp), then redefined in TCustomForm and finally redefined in TForm.
+
<syntaxhighlight lang=pascal>var
Invoking find declaration on Visible will you first bring to Visible in TForm. Then you can invoke Find Declaration again to jump to Visible in TCustomForm and again to jump to Visible in TControl.
+
  {Comment}
 +
  Identifier: integer;</syntaxhighlight>
  
Same is true for types like TColor.
+
Kommentare mit dem '''<'''-Zeichen gehören zum vorhergehenden Bezeichner.
For the compiler it is simply a 'longint'. But in the sources it is defined as
 
TGraphicsColor = -$7FFFFFFF-1..$7FFFFFFF;
 
TColor = TGraphicsColor;
 
  
And the same for forward defined classes:
+
Kommentare hinter einem Bezeichner in der selben Zeile:
For instance in TControl, there is a private variable
 
FHostDockSite: TWinControl;
 
Find declaration on TWinControl jumps to the forward definition
 
TWinControl = class;
 
And invoking it again jumps to the real implementation
 
TWinControl = class(TControl)
 
This way you can track down every identifier and find every overload.
 
  
==Goto Include Directive==
+
<syntaxhighlight lang=pascal>var
"Goto Include Directive" in the search menu of the IDE jumps to {$I filename} statement where the current include file is used.
+
  identifier, // Comment
 +
  other,</syntaxhighlight>
  
==Publish Project==
+
Kommentare hinter der Definition in der selben Zeile:
Creates a copy of the whole project. If you want to send someone just the sources and compiler settings of your code, this function is your friend.
 
  
A normal project directory contains a lot of information. Most of it is not needed to be published:
+
<syntaxhighlight lang=pascal>var
The .lpi file contains session information (like caret position and bookmarks of closed units) and the project directory contains a lot of .ppu, .o files and the executable.
+
  identifier:
To create a lpi file with only the base information and only the sources, along with all sub directories use "Publish Project".
+
    char; // Comment</syntaxhighlight>
 +
 
 +
Ein Beispiel für das '''<'''-Zeichen:
 +
 
 +
<syntaxhighlight lang=pascal>const
 +
  a = 1;
 +
  //< comment for a
 +
  b = 2;
 +
  // comment for c
 +
  c = 3;</syntaxhighlight>
 +
 
 +
Alle drei Kommentartypen werden unterstützt:
 +
<syntaxhighlight lang=pascal>  {Comment}(*Comment*)//Comment
 +
  c = 1;</syntaxhighlight>
 +
 
 +
Kommentare, die mit '''$''' und '''%''' beginnen, werden ignoriert.
 +
 
 +
===Kommentare, nicht im Tipp angezeigt===
 +
 
 +
Vorlaufende Kommentare, die mit einer Leerzeile abgetrennt werden, werden als unspezifisch für den folgenden Bezeichner angesehen. Beispielsweise wird der Kommentar für den folgenden Klassenheader nicht im Tipp angezeigt:
 +
 
 +
<syntaxhighlight lang=pascal>type
 +
  { TMyClass }
 +
 
 +
  TMyClass = class</syntaxhighlight>
  
'''Note''': Since version 0.9.13 there is a new ''Project Option'' that allows you to store session information in a seperate file from the normal .lpi file.  This new file ends with the .lps extension and only contains session information, which will leave you .lpi file much cleaner.
+
Die Kommentare für Klassenheader werden bei der Klassenvervollständigung erzeugt. Sie können dies ausschalten unter ''Einstellungen / Codetools / Klassenvervollständigung / Header-Kommentar für die Klasse''. Falls Sie den Header-Kommentar im Tipp anzeigen wollen, entfernen Sie einfach die Leerzeile.
  
In the dialog you can setup the exclude and include filter, and with the command after you can compress the output into one archive.
+
Der folgende Kommentar wird angezeigt für GL_TRUE, aber nicht für GL_FALSE:
  
==Ursprüngliche Mitwirkende==
+
<syntaxhighlight lang=pascal>  // Boolean
Diese Seite wurde von der epikwiki [http://lazarus-ccr.sourceforge.net/index.php?wiki=LazarusIdeTools Version] konvertiert.
+
  GL_TRUE                          = 1;
* Created page and initial template - 4/6/2004 [[User:Tom Lisjac| VlxAdmin]]
+
  GL_FALSE                          = 0;</syntaxhighlight>
* Initial content posted - 4/10/2004 MattiasG
 
* Small wiki and formatting fixes - 4/11/2004 [[User:Tom Lisjac| VlxAdmin]]
 
* Added a summary table for IdeTools shortcuts - 12 July 2004 [[User:Kirkpatc]]
 

Latest revision as of 19:42, 21 February 2022

Deutsch (de) English (en) español (es) suomi (fi) français (fr) 日本語 (ja) 한국어 (ko) Nederlands (nl) português (pt) русский (ru) slovenčina (sk) 中文(中国大陆)‎ (zh_CN)

Überblick

Die IDE verwendet eine Bibliothek von Werkzeugen zum Analysieren und Bearbeiten von Pascal-Quelltexten, genannt die "CodeTools". Diese Werkzeuge bieten Features wie Deklaration finden, Codevervollständigung, Isolation, Verschieben, Einfügen und Verschönern von Pascal-Quelltext. Diese Funktionen sparen Ihnen eine Menge Zeit und doppelte Arbeit. Sie können angepasst werden. Jedes Feature ist über Tastenkombinationen verfügbar (siehe Editoreinstellungen).

Weil sie ausschließlich mit Quelltexten arbeiten und den Code von FPC, Delphi und Kylix verstehen, benötigen sie weder kompilierte Units noch einen installierten Borland Compiler. Sie können Delphi- und FPC-Code zur gleichen Zeit bearbeiten. Sie können sogar mit verschiedenen Delphi- und FPC-Versionen zur selben Zeit arbeiten. Dies macht die Portierung von Delphi-Code sehr viel einfacher.

Übersichtstabelle der IDE-Tastenkombinationen

Declaration Jumping Strg+Klick (springt zur Deklaration eines Typs oder einer Variablen)
Methodenspringen Strg+ Shift+ (schaltet zwischen Definition und Rumpf einer Prozedur/Methode um)
Code-Schablonen Strg+J
Synchronbearbeitung Strg+J (bei ausgewähltem Text)
Codevervollständigung (Klassenvervollständigung) Strg+ Shift+C
Bezeichner-Vervollständigung Strg+Space
Wortvervollständigung Strg+W
Parameter-Hinweise Strg+ Shift+Space
Inkrementelle Suche Strg+E
Bezeichner umbenennen Strg+ Shift+E

Methodenspringen

Um zwischen einem Prozedurrumpf (begin..end) und der Prozedurdefinition (procedure Name;) zu springen, verwenden Sie Strg+ Shift+Nach oben.

Zum Beispiel:

interface

procedure DoSomething; // Prozedurdefinition

implementation

procedure DoSomething; // Prozedurrumpf 
begin
end;

Wenn der Cursor auf dem Prozedurrumpf ist und Sie Strg+ Shift+Nach oben drücken, dann wird der Kursor zur Definition springen. Erneutes Drücken von Strg+ Shift+Nach oben wird wieder zum Rumpf springen, nach 'begin'.

Dies funktioniert ebenfalls zwischen Methoden (Prozeduren in Klassen).

Hinweise: Methodenspringen springt zur selben Prozedur mit dem selben Namen und Parameterliste. Wenn es keine bestimmte Prozedur gibt, springt es zum besten Kandidaten und positioniert den Kursor auf dem ersten Unterschied. (Für Delphianer: Delphi kann dies nicht tun).

Zum Beispiel eine Prozedur mit verschiedenen Parametertypen:

interface

procedure DoSomething(p: char); // Prozedurdefinition

implementation
  
procedure DoSomething(p: string); // Prozedurrumpf
begin
end;

Das Springen von der Definition zum Rumpf wird den Kursor auf dem 'string' Schlüsselwort positionieren. Dies kann verwendet werden für das Umbenennen von Methoden und/oder das Ändern von Parametern.

Zum Beispiel:
Sie benannten 'DoSomething' in 'MakeIt' um:

interface

procedure MakeIt; // Prozedurdefinition

implementation

procedure DoSomething; // Prozedurrumpf
begin
end;

Dann springen Sie von MakeIt zum Rumpf. Die IDE sucht nach einem passenden Rumpf, findet keinen, und sucht daher nach einem Kandidaten. Weil Sie nur eine Prozedur umbenannt haben, gibt es exakt einen Rumpf ohne Definition (DoSomething) und daher wird sie zu DoSomething springen und den Kursor rechts neben 'DoSomething' positionieren. Dann können Sie sie dort auch umbenennen. Das funktioniert ebenfalls für Parameter.

Include-Dateien

Include-Dateien sind Dateien, die mit der ($I Dateiname) oder ($INCLUDE Dateiname) Compilerdirektive in die Quellen eingefügt werden. Lazarus und FPC verwenden oft Include-Dateien, um Redundanz zu reduzieren und unlesbare ($IFDEF) Konstrukte zu vermeiden um verschiedene Plattformen zu unterstützen.

Im Gegensatz zu Delphi bietet die Lazarus IDE volle Unterstützung für Include-Dateien. Sie können zum Beispiel von der Methode in der .pas Datei zum Methodenrumpf in der Include-Datei springen. Alle CodeTools wie Codevervollständigung berücksichtigen Include-Dateien als spezielle Schranken.

Zum Beispiel: Wenn die Codevervollständigung einen neuen Methodenrumpf hinzufügt hinter anderen Methodenrümpfen, behält sie beide in der selben Datei. Auf diese Weise können Sie ganze Klassenimplementierungen in Include-Dateien verwenden, wie es die LCL für nahezu alle Bedienelemente tut.

Aber es gibt eine Anfängerfalle: Wenn Sie eine Include-Datei zum ersten Mal öffnen und method jumping oder find declaration ausprobieren, erhalten Sie eine Fehlermeldung. Die IDE weiß nicht, zu welcher Unit die Include-Datei gehört. Sie müssen die Unit zuerst öffnen.

Sobald die IDE die Unit analysiert, wird sie die Include-Direktive dort finden und die IDE wird sich an diese Beziehung erinnern. Sie wird diese Informationen beim Beenden (oder beim Speichern des Projekts) speichern in der Datei ~/.lazarus/includelinks.xml. Wenn Sie diese Include-Datei das nächste Mal öffnen und eine 'find declaration' durchführen, wird die IDE die Unit intern öffnen und das Springen wird funktionieren. Sie können die IDE auch direkt hinweisen mit

{%mainunit yourunit.pas}

am Anfang Ihrer yourinclude.inc.

Dieser Mechanismus hat natürlich Grenzen. Einige Include-Dateien sind zweimal oder mehrfach einbezogen. Zum Beispiel: lcl/include/winapih.inc.

Das Springen von den Prozedur-/Methodendefinitionen in diese Include-Datei zu den Rümpfen hängt von Ihren letzten Aktionen ab. Wenn Sie an lcl/lclintf.pp gearbeitet haben dann wird die IDE zu winapi.inc springen. Wenn Sie an lcl/interfacebase.pp gearbeitet haben, dann wird sie zu lcl/include/interfacebase.inc springen (oder einer der anderen Include-Dateien). Wenn Sie an beiden arbeiten, dann können Sie verwirrt werden. ;)

Code-Schablonen

Code-Schablonen konvertieren einen Bezeichner in einen Text oder Code-Fragment.

Die Code-Schablonen Vorgabetastenkombination ist Strg+J. Sie können einen Bezeichner eintippen, Strg+J drücken und der Bezeichner wird durch den Text ersetzt, der für den Bezeichner definiert ist. Code-Schablonen können definiert werden in Werkzeuge -> Vorlagen.

Beispiel: Schreiben Sie den Bezeichner 'classf', lassen Sie den Kursor hinter dem 'f' stehen und drücken Sie Strg+J. Das 'classf' wird ersetzt durch

T = class(T)
private

public
  constructor Create;
  destructor Destroy; override;
end;

und der Cursor ist hinter dem 'T'. Sie können die Liste der Vorlagen abrufen, in dem Sie den Kursor an eine freie Stelle positionieren (nicht auf einem Bezeichner) und Strg+J drücken. Die Liste der Code-Schablonen wird auftauchen. Verwenden Sie die Kursortasten oder tippen Sie einige Buchstaben um eine auszuwählen. Eingabe erzeugt die gewählte Vorlage und Escapeschließt das Popup-Fenster.

Die größten Zeitsparer sind die Schablonen 'b'+Strg+J für begin..end.

Parameter-Hinweise

Parameter-Hinweise zeigen eine Hinweisbox mit den Parameter-Deklarationen für die aktuelle Parameterliste.

Zum Beispiel

  Canvas.FillRect(|);

Platzieren Sie den Cursor in den Klammern und drücken Sie Strg+ Shift+Leertaste. Eine Hinweisbox erscheint mit den Parametern von FillRect.

Parameterhints1.png

Seit Version 0.9.31 gibt es eine Schaltfläche rechts neben jeder Deklaration um fehlende Parameters einzufügen. Diese kopiert die Parameternamen aus der ausgewählten Deklaration an die Kursorposition.

Parameterhints2.png

Tipp: Benutzen Sie die Variable Declaration Completion um Variablen zu deklarieren.

Beachten Sie: Der Name des Tastenkürzels ist "Code-Context anzeigen".

Inkrementelle Suche

Die inkrementelle Suche ändert die Statuszeile des Quelltexteditors. Geben Sie ein paar Zeichen ein und der Editor sucht und markiert sofort alle Fundstellen im Text. Das Tastaturkürzel ist Strg+E.

  • Zum Beispiel: Sie drücken A, sucht und markiert alle Fundstellen von 'A'.
  • Dann drücken Sie T und alle Fundstellen von 'at' sind markiert usw.
  • Sie springen zur nächsten Fundstelle mit F3 (oder Strg+E während der Suche) und zur vorigen Fundstelle mit Umschalt+F3.
  • ← Backspace entfernt das letzte Zeichen
  • Eingabe stoppt die Suche ohne eine neue Zeile im Editor.
  • Sie nehmen die letzte Suche erneut auf mit einem zweiten Strg+E, sofort nach dem Start der Suche mit Strg+E. Das gilt solange das Suchfeld noch leer ist.
  • Einfügen mit Strg+V hängt den Text aus der Zwischenablage an den aktuellen Suchtext an (seit Lazarus 0.9.27 r19824).

Hinweis: Schnelle Suche nach einem Bezeichner mit der inkrementellen Suche

  • Stellen Sie den Textkursor auf den Bezeichner. (Wählen Sie nichts aus!)
  • Drücken Sie Strg+C. Der Editor wählt den Bezeichner aus und kopiert ihn in die Zwischenablage
  • Drücken Sie Strg+E - startet die inkrementelle Suche
  • Drücken Sie Strg+V - sucht nach dem Bezeichner (seit Version 0.9.27)
  • Mit F3 und Umschalt+F3 springen Sie zum nächsten/vorigen Fund.
  • Mit einer beliebigen Taste (beispielsweise Kursor links oder rechts) beenden Sie die Suche

Synchronbearbeitung

Die Synchronbearbeitung ermöglicht es Ihnen, alle Fundstellen eines Wortes gleichzeitig (synchronisiert) zu bearbeiten. Sie bearbeiten einfach das Wort an einer Stelle und gleichzeitig mit Ihren Eingaben werden auch alle anderen Fundstellen des Wortes aktualisiert.

Die Synchronbearbeitung verarbeitet alle Worte in einem ausgewählten Bereich:

  • Selektieren Sie einen Textblock
  • Drücken Sie Strg+J oder klicken Sie auf das Symbol in der Randleiste. (Das funktioniert nur, wenn Worte in der Auswahl mehr als einmal auftreten.)
  • Benutzen Sie die Tab -Taste, um das zu bearbeitende Wort auszuwählen (wenn einige verschiedene Wörter mehrfach auftreten).
  • Bearbeiten Sie das Wort.
  • Drücken Sie Esc zum Beenden

Sehen Sie sich hier ein animiertes Beispiel an.

  • Anmerkung: Strg+J wird auch beim Bearbeiten von Vorlagen benutzt. Die Bedeutung ändert sich, wenn Sie einen Text auswählen.

Suche nächste / vorhergehende Fundstelle des Wortes

Die zwei Funktionen sind im Kontextmenü des Quelltexteditors zu finden

  • Quelltexteditor / Kontextmenü / Suchen / Nächste Fundstelle des Wortes
  • Quelltexteditor / Kontextmenü / Suchen / Vorhergehende Fundstelle des Wortes

Und Sie können diesen Funktionen in den Editoreinstellungen ein Tastenkürzel zuweisen.

Codevervollständigung

Die Codevervollständigung ist im IDE-Menü zu finden unter Bearbeiten -> Quelltext vervollständigen und hat das Standardkürzel Strg+ Shift+C.

Für Delphianer: Delphi bezeichnet mit "Codevervollständigung" die Funktion, die die Liste der Bezeichner an der aktuellen Quellenposition zeigt (Strg+Leertaste). Unter Lazarus wird dies Bezeichnervervollständigung genannt.

Codevervollständigung kombiniert verschiedene mächtige Funktionen. Beispiele:

Welche Funktion genutzt wird, hängt von der Kursorposition im Editor ab und wird unten beschrieben.

Die Codevervollständigung ist im IDE-Menü zu finden unter Bearbeiten -> Quelltext vervollständigen und hat das Standardkürzel Strg+ Shift+C.

Class Completion

Das mächtigste Codevervollständigungs-Feature ist Class Completion. Sie schreiben eine Klasse, fügen die Methoden und Eigenschaften hinzu und Codevervollständigung wird die Methodenrümpfe hinzufügen, die Methoden/Variablen des Eigenschaftszugriffs und die private Variablen.

Zum Beispiel: Erzeugen Sie eine Klasse (siehe Code-Schablonen, um einige Tipparbeit zu sparen):

TExample = class(TObject)
public
  constructor Create;
  destructor Destroy; override;
end;

Positionieren Sie den Kursor irgendwo in der Klasse und drücken Sie Strg+ Shift+C. Dies wird die fehlenden Methodenrümpfe erzeugen und den Kursor zu dem ersten erzeugten Methodenrumpf bewegen, so dass Sie jetzt mit dem Schreiben des Klassencodes beginnen können:

{ TExample }

constructor TExample.Create;
begin
  |
end;

destructor TExample.Destroy;
begin
  inherited Destroy;
end;

Anmerkung: Das '|' ist der Kursor und nicht hinzugefügt.

Hinweis: Sie können zwischen einer Methode und ihrem Rumpf springen mit Strg+ Shift+Nach oben.

Sie können sehen, dass die IDE auch den 'inherited Destroy' Aufruf hinzugefügt hat. Dies passiert, wenn es ein 'override' Schlüsselwort in der Klassendefinition gibt.

Jetzt fügen Sie eine Methode DoSomething hinzu:

TExample = class(TObject)
public
  constructor Create;
  procedure DoSomething(i: integer);
  destructor Destroy; override;
end;

Dann drücken Sie Strg+ Shift+C und die IDE wird hinzufügen:

procedure TExample.DoSomething(i: integer);
begin
  |
end;

Sie sehen, der neue Methodenrumpf wurde zwischen Create und Destroy eingefügt, exakt wie in der Klassendefinition. So behalten auch die Methodenrümpfe die gleiche logische Ordnung bei (wie von Ihnen festgelegt). Sie legen die Einfügerichtlinien fest in Einstellungen -> Codetools Einstellungen -> Quelltexterzeugung.

Complete Properties
Fügen Sie eine Eigenschaft 'AnInteger' hinzu:

TExample = class(TObject)
public
  constructor Create;
  procedure DoSomething(i: integer);
  destructor Destroy; override;
  property AnInteger: Integer;
end;

Drücken Sie Ctrl+ Shift+C und Sie erhalten:

procedure TExample.SetAnInteger(const AValue: integer);
begin
  |if FAnInteger=AValue then exit;
  FAnInteger:=AValue;
end;

Die Codevervollständigung hat den Schreibzugriff geändert und den üblichen Code ergänzt. Springen Sie mit Strg+ Shift+Nach oben zur Klasse, um die neue Klasse ganz zu sehen:

TExample = class(TObject)
private
  FAnInteger: integer;
  procedure SetAnInteger(const AValue: integer);
public
  constructor Create;
  procedure DoSomething(i: integer);
  destructor Destroy; override;
  property AnInteger: integer read FAnInteger write SetAnInteger;
end;

Die Eigenschaft wurde um einen Lese- und Schreibzugriff erweitert. Die Klasse erhielt den neuen Abschnitt 'private' mit einer Variable 'FAnInteger' und der Methode 'SetAnInteger'. Es ist eine allgemein übliche Delphi-Stil-Regel, den privaten Variablen ein 'F' und der write-Methode ein 'Set' voranzustellen. Wenn Sie das nicht mögen, können Sie es ändern unter Einstellungen -> Codetools Einstellungen -> Quelltexterzeugung.

Erzeugen einer Eigenschaft 'read only':

property PropName: PropType read;

wird erweitert zu

property PropName: PropType read FPropName;

Erzeugen einer Eigenschaft 'write only':

property PropName: PropType write;

wird erweitert zu

property PropName: PropType write SetPropName;

Erzeugen einer Eigenschaft 'read only' mit einer Read-Methode:

property PropName: PropType read GetPropName;

wird beibehalten und eine Funktion 'GetPropName' wird angefügt:

function GetpropName: PropType;

Erzeugen einer Eigenschaft mit einem stored-Modifizierer:

property PropName: PropType stored;

wird erweitert zu

property PropName: PropType read FPropName write SetPropName stored PropNameIsStored;

Weil 'stored' für das Streaming benutzt wird, werden automatisch auch die read- und write-Modifizierer angefügt.

Hinweis: Die Bezeichnervervollständigung erkennt auch unvollständige Eigenschaften und wird die Standardnamen vorschlagen. Zum Beispiel:

property PropName: PropType read |;

Platzieren Sie den Kursor eine Leerstelle hinter dem 'read'-Schlüsselwort und drücken Strg+Space für die Bezeichnervervollständigung. Diese wird Ihnen die Variable 'FPropName' und die Prozedur 'SetPropName' präsentieren.

Forward Procedure Completion

Die Forward Procedure Completion ist ein Teil der Codevervollständigung und fügt fehlende Prozedurrümpfe hinzu. Sie wird aufgerufen, wenn der Kursor auf einer vorwärts definierten Prozedur ist.

Zum Beispiel: Fügen Sie eine neue Prozedur zum Interface-Abschnitt hinzu:

procedure DoSomething;

Platzieren Sie den Kursor darauf und drücken Sie Strg+ Shift+C für Codevervollständigung. Es wird im Implementation-Abschnitt erzeugen:

procedure DoSomething;
begin
  |
end;

Hinweis: Sie können zwischen einer Prozedurdefinition und ihrem Rumpf springen mit Strg+ Shift+Nach oben.

Der neue Prozedurrumpf wird vor den Klassenmethoden eingefügt. Wenn es bereits einige Prozeduren im Interface-Abschnitt gibt, versucht die IDE die Ordnung einzuhalten. Zum Beispiel:

procedure Proc1;
procedure Proc2; // neue Prozedur
procedure Proc3;

Wenn die Rümpfe von Proc1 und Proc3 bereits existieren, dann wird der Proc2 Rumpf zwischen den Rümpfen von Proc1 und Proc3 eingefügt. Dieses Verhalten kann eingestellt werden in Einstellungen -> CodeTools Einstellungen -> Quelltexterzeugung.

Mehrere Prozeduren:

procedure Proc1_Old; // Rumpf existiert
procedure Proc2_New; // Rumpf existiert nicht
procedure Proc3_New; //  "
procedure Proc4_New; //  "
procedure Proc5_Old; // Rumpf existiert

Die Codevervollständigung wird alle 3 Prozedurrümpfe hinzufügen (Proc2_New, Proc3_New, Proc4_New).

Warum wird das Forward Procedure Completion genannt?

Weil es nicht nur für Prozeduren funktioniert, die im Interface definiert sind, sondern auch für Prozeduren mit dem "forward"-Bezeichner. Und weil die CodeTools Prozeduren im Interface so behandeln als hätten sie einen impliziten "forward"-Bezeichner.

Event Assignment Completion

Die "Event Assignment Completion" ist ein Teil der Codevervollständigung und komplettiert eine einzelne Ereignis:=| Anweisung. Sie wird aufgerufen, wenn der Kursor hinter einer Ereigniszuweisung steht.

Zum Beispiel: In einer Methode, sagen wir dem FormCreate Ereignis, fügen wir eine Zeile 'OnPaint:=' hinzu:

procedure TForm1.Form1Create(Sender: TObject);
begin
  OnPaint:=|
end;

Das '|' ist der Kursor und sollte nicht eingegeben werden. Dann drücken sie Strg+Shift+C für die Codevervollständigung. Die Anweisung wird komplettiert zu

OnPaint:=@Form1Paint;

Eine neue Methode Form1Paint wird zur Klasse TForm1 hinzugefügt. Dann wird die class completion gestartet und Sie erhalten:

procedure TForm1.Form1Paint(Sender: TObject);
begin
  |
end;

Das funktioniert wie das Hinzufügen von Methoden im Objektinspektor.

Anmerkung:
Sie müssen den Kursor hinter dem ':=' Zuweisungsoperator platzieren. Wenn Sie den Kursor auf dem Bezeichner platzieren (z.B. OnPaint) wird die Codevervollständigung die "Local Variable Completion" aufrufen, was fehlschlägt, weil OnPaint bereits definiert ist.

Hinweis:
Sie können den neuen Methodennamen selbst definieren. Zum Beispiel:

OnPaint:=@ThePaintMethod;

Variable Declaration Completion

Die "Variable Declaration Completion" ist ein Teil der Codevervollständigung und fügt eine lokale Variablendefinition zu einer Identifier:=Term; Anweisung hinzu. Sie wird aufgerufen, wenn der Kursor auf dem Bezeichner in einer Zuweisung oder einem Parameter ist.

Zum Beispiel:

procedure TForm1.Form1Create(Sender: TObject);
begin
  i:=3;
end;

Platzieren Sie den Kursor auf dem 'i' oder genau dahinter. Dann drücken Sie Strg+ Shift+C für die Codevervollständigung und Sie erhalten:

procedure TForm1.Form1Create(Sender: TObject);
var
  i: Integer;
begin
  i:=3;
end;

Die CodeTools prüfen zuerst, ob der Bezeichner 'i' bereits definiert ist und wenn nicht werden sie die Deklaration 'var i: integer;' hinzufügen. Der Typ des Bezeichners wird erraten vom Ausdruck rechts des ':=' Zuweisungsoperators. Zahlen wie die 3 sind mit Integer vorbelegt.

Ein anderes Beispiel:

type
  TWhere = (Behind, Middle, InFront);
 
  procedure TForm1.Form1Create(Sender: TObject);
  var
    a: array[TWhere] of char;
  begin
    for Where:=Low(a) to High(a) do writeln(a[Where]);
  end;

Platzieren Sie den Kursor auf 'Where' und drücken Sie Strg+ Shift+C für die Codevervollständigung. Sie erhalten:

  procedure TForm1.Form1Create(Sender: TObject);
  var
    a: array[TWhere] of char;
    Where: TWhere;
  begin
    for Where:=Low(a) to High(a) do writeln(a[Where]);
  end;

Seit Version 0.9.11 komplettiert Lazarus auch Parameter. Zum Beispiel

  procedure TForm1.FormPaint(Sender: TObject);
  begin
    with Canvas do begin
      Line(x1,y1,x2,y2);
    end;
  end;

Platzieren Sie den Kursor auf 'x1' und drücken Sie Strg+ Shift+C für die Codevervollständigung. Sie erhalten:

  procedure TForm1.FormPaint(Sender: TObject);
  var
    x1: integer;
  begin
    with Canvas do begin
      Line(x1,y1,x2,y2);
    end;
  end;

Procedure Call Completion

Die Codevervollständigung kann auch eine neue Prozedur aus dem Prozeduraufruf selbst erzeugen.

Angenommen, Sie haben gerade die Anweisung "DoSomething(Width);" geschrieben

procedure SomeProcedure;
var
  Width: integer;
begin
  Width:=3;
  DoSomething(Width);
end;

Platzieren Sie den Kursor über dem Bezeichner "DoSomething" und drücken Sie Strg+ Shift+C. Sie erhalten:

procedure DoSomething(aWidth: LongInt);
begin

end;

procedure SomeProcedure;
var
  Width: integer;
begin
  Width:=3;
  DoSomething(Width);
end;

Es werden derzeit noch keine Funktionen oder Methoden erzeugt.

Reversed Class Completion

"Reversed Class Completion" ist ein Teil der Codevervollständigung und fügt eine private Methodendeklaration zum aktuellen Methodenrumpf hinzu. Sie wird aufgerufen, wenn der Cursor in einem Methodenrumpf ist, der noch nicht in der Klasse definiert wurde. Dieses Feature ist seit Lazarus 0.9.21 verfügbar.

Zum Beispiel:

  procedure TForm1.DoSomething(Sender: TObject);
  begin
  end;

Die Methode DoSomething ist noch nicht in TForm1 deklariert. Drücken Sie Strg+ Shift+C und die IDE wird "procedure DoSomething(Sender: TObject);" zu den privaten Methoden von TForm1 hinzufügen.

Für Delphianer: Die Klassenergänzung arbeitet unter Lazarus immer in einer Richtung: Von dem Klasseninterface zur Implementation oder rückwärts/umgekehrt von der Klassenimplementation zum Interface. Delphi ruft immer beide Richtungen auf. Das Delphi-Verfahren hat den Nachteil, dass bei einem Rechtschreibfehler leicht eine neue Methodenvorlage erzeugt wird ohne Benachrichtigung.

Kommentare und Codevervollständigung

Die Codevervollständigung versucht die Kommentare dort zu behalten, wo sie hingehören. Zum Beispiel:

  FList: TList; // list of TComponent
  FInt: integer;

Wenn eine neue Variable zwischen FList und FInt eingesetzt wird, dann wird der Kommentar in der FList Zeile beibehalten. Das selbe gilt für

  FList: TList; { list of TComponent
    Dies ist ein Kommentar über mehrere Zeilen, beginnend
    in der FList-Zeile. Die CodeTools nehmen an, er gehöre 
    zu der FList-Zeile und brechen diese Beziehung nicht
    auf. Der Code wird hinter dem Kommentar eingefügt. }
  FInt: integer;

Wenn der Kommentar in der nächsten Zeile startet, dann wird er behandelt, wie wenn er zum nachfolgenden Code gehört. Zum Beispiel:

  FList: TList; // list of TComponent
    { Dieser Kommentar gehört zur nachfolgenden Anweisung. 
      Neuer Code wird oberhalb des Kommentars eingefügt und 
      hinter dem Kommentar der FList-Zeile. }
  FInt: integer;

Method update

Normalerweise fügt die Klassenergänzung alle fehlenden Methodenrümpfe ein. (Seit Version 0.9.27) Falls sich aber genau eine Methode zwischen Klassendeklaration und Rümpfen unterscheidet, dann wird der Methodenrumpf aktualisiert. Zum Beispiel: Sie haben eine Methode DoSomething.

  public
    procedure DoSomething;
  end;

procedure TForm.DoSomething;
begin
end;

Fügen Sie jetzt einen Parameter hinzu:

  public
    procedure DoSomething(i: integer);
  end;

und rufen Sie die Codevervollständigung auf mit (Strg+ Shift+C). Der Methodenrumpf wird aktualisiert und der neue Parameter wird kopiert:

procedure TForm.DoSomething(i: integer);
begin
end;

Refactoring

Invert Assignments

Kurz gefasst
"Invert Assignments" nimmt einige ausgewählte Pascal-Anweisungen und invertiert alle Zuweisungen aus diesem Code. Dieses Werkzeug ist hilfreich für das Umwandeln eines "Speicher"-Codes in einen "Lade"-Code und umgekehrt.

Beispiel:

procedure DoSomething;
begin
  AValueStudio:= BValueStudio;
  AValueAppartment :=BValueAppartment;
  AValueHouse:=BValueHouse;
end;

Wählen Sie die Zeilen mit den Zuweisungen aus (zwischen begin und end) und führen Sie "Invert Assignments" aus. Alle Zuweisungen werden invertiert und die Einrückung wird automatisch hinzugefügt. Zum Beispiel:

Resultat:

procedure DoSomething;
begin
  BValueStudio     := AValueStudio;
  BValueAppartment := AValueAppartment;
  BValueHouse      := AValueHouse;
end;

Enclose Selection

Wählen Sie einigen Text aus und rufen Sie die Vervollständigung auf. In dem aufscheinenden Dialog können Sie auswählen, ob der selektierte Text in try..finally oder einen der vielen anderen üblichen Blöcke eingeschlossen werden soll.

Bezeichner umbenennen

Stellen Sie den Kursor auf einen Bezeichner und rufen Sie die Vervollständigung auf. Es erscheint ein Dialog, wo Sie den Suchbereich und den neuen Namen festlegen können.

  • Es werden alle Vorkommen umbenannt und zwar nur jene, die tatsächlich diese Deklaration verwenden. Das bedeutet, dass nicht automatisch alle Deklarationen mit dem selben Namen umbenannt werden.
  • Und es wird zuerst auf Namenskonflikte überprüft.
  • Beschränkungen: Das funktioniert nur mit Pascal-Quellen, benennt keine Dateinamen um und bearbeitet weder lfm/lrs-Dateien noch lazdoc-Dateien.

Find Identifier References

Stellen Sie den Kursor auf einen Bezeichner und rufen Sie die Vervollständigung auf. Es erscheint ein Dialog, wo Sie den Suchbereich festlegen können. Die IDE sucht dann nach allen Vorkommen und nur solchen, die tatsächlich diese Deklaration verwenden. Das bedeutet, dass nicht andere Deklarationen mit dem selben Namen angezeigt werden.

Show abstract methods

Dieses Merkmal listet und ergänzt automatisch virtuelle, abstrakte Methoden, die noch implementiert werden müssen. Stellen Sie den Kursor auf eine Klassendeklaration und rufen Sie die Vervollständigung auf. Falls es fehlende abstrakte Methoden gibt, werden diese in einem Dialog aufgelistet. Wählen Sie die zu implementierende Methode aus und die IDE erzeugt eine Methodenschablone.

Prozedur extrahieren

Siehe Prozedur extrahieren

Find Declaration

Positionieren Sie den Kursor auf einem Bezeichner und starten Sie Find Declaration. Das wird die Deklaration dieses Bezeichners suchen, die Datei öffnen und zu ihr springen. Falls der Kursor bereits auf der Deklaration ist, erfolgt ein Sprung zur vorherigen Deklaration mit dem selben Name. Dies erlaubt es, Neudefinitionen und Overrides zu finden.

Jede find declaration setzt einen Sprungpunkt. Das bedeutet, Sie springen mit find declaration zur Deklaration und einfach zurück mit Suche -> Zurückspringen.

Es gibt einige Unterschiede zu Delphi: Die CodeTools arbeiten mit den Quellen, den normalen Pascal-Regeln folgend, anstelle der Verwendung der Compiler-Ausgaben. Der Compiler liefert den finalen Typ zurück. Die CodeTools sehen die Quellen und alle Schritte dazwischen. Zum Beispiel:

Die Visible Eigenschaft wird zuerst in TControl (controls.pp) definiert, dann neu definiert in TCustomForm und letztlich in TForm neu definiert. Das Aufrufen von find declaration auf Visible wird Sie zuerst zu Visible in TForm bringen. Dann können Sie Find Declaration erneut aufrufen um zu Visible in TCustomForm zu springen und nochmals, um zu Visible in TControl zu springen.

Das selbe gilt für Typen wie TColor. Für den Compiler ist es einfach ein 'longint'. Aber in den Quellen ist es definiert als

TGraphicsColor = -$7FFFFFFF-1..$7FFFFFFF;
TColor = TGraphicsColor;

Und das selbe für forward defined classes: Zum Beispiel gibt es in TControl eine private Variable

FHostDockSite: TWinControl;

Find declaration auf TWinControl springt zur forward definition

TWinControl = class;

Und ein erneuter Aufruf springt zur realen Implementierung

TWinControl = class(TControl)

Auf diese Weise können Sie jeden Bezeichner aufspüren und jede Überladung finden.

Tipps:

  • Sie können zurück springen mit Strg+H.
  • Sie können alle besuchten Orte anzeigen/erreichen mittels Menü: Ansicht / Sprungliste anzeigen ...
  • Mit einer 5-Tasten-Maus können Sie die beiden Extratasten dazu verwenden, vorwärts/rückwärts zu den besuchten Orten zu gehen
(Sie können die Tastenbelegung ändern mit Menü: Einstellungen / Maus / Erweitert

Siehe auch: advanced mouse options)

Bezeichner-Vervollständigung

Die "Bezeichner-Vervollständigung" wird aufgerufen mittels Strg+space. Sie zeigt alle Bezeichner im Suchbereich. Zum Beipiel:

procedure TForm1.FormCreate(Sender: TObject);
begin
  |
end;

Stellen Sie den Kursor zwischen begin und end und drücken Sie Strg+space. Die IDE/CodeTools untersuchen nun den gesamten erreichbaren Code und präsentieren Ihnen eine Liste aller gefundenen Bezeichner. Die CodeTools speichern die Ergebnisse zwischen, sodass ein neuerlicher Aufruf sehr viel schneller verläuft.

Anmerkung für Delphianer: Delphi nennt das Code completion.

Einige Bezeichner wie 'Write', 'ReadLn', 'Low', 'SetLength', 'Self', 'Result', 'Copy' sind in den Compiler eingebaut und nirgends sonst im Quellcode definiert. Die Bezeichner-Vervollständigung hat ebenfalls viele solche Dinge eingebaut. Falls Ihnen eines fehlt, schreiben Sie einfach einen Wunsch ("feature request") im Bug-Tracker.

Die Bezeichner-Vervollständigung ergänzt nicht alle Schlüsselwörter. So können Sie sie nicht dazu benutzen 'repe' zu 'repeat' zu ergänzen. Nehmen Sie dafür Strg+W Wortvervollstandigung oder Strg+J Code-Schablonen. Seit Version 0.9.27 ergänzt die Bezeichner-Vervollständigung einige Schlüsselwörter.

Die Bezeichner-Vervollständigung zeigt sogar solche Bezeichner an, die inkompatibel sind.

Präfix

Sie könne die Bezeichner-Vervollständigung mitten in einem Wort starten. Dann werden die Buchstaben links als Präfix genommen. Zum Beispiel:

procedure TForm1.FormCreate(Sender: TObject);
begin
  Ca|ption
end;

Die Suchliste zeigt Ihnen dann nur diejenigen Bezeichner an, die mit 'Ca' beginnen.

Tasten

  • Buchstabe oder Ziffer: füge das Zeichen hinzu im Quelltexteditor und im aktuellen Präfix. Dadurch wird die Liste aktualisiert.
  • Backspace: entfernt das letzte Zeichen aus dem Quelltexteditor und dem Präfix. Aktualisiert die Liste.
  • Eingabe: ersetzt das ganze Wort am Kursor mit dem ausgewählten Bezeichner und schließt das Popup-Fenster.
  • Umschalt+Eingabe: wie Eingabe, aber ersetzt nur das Präfix (linker Teil) des Wortes am Kursor.
  • Nach oben/Nach unten: bewegt die Auswahl
  • Escape: schließt das Popup-Fenster ohne Änderungen
  • Tab: ergänzt das Präfix zur nächsten Auswahl. Zum Beispiel: Das aktuelle Präfix ist 'But' und die Bezeichner-Vervollständigung zeigt nur 'Button1' und 'Button1Click'. Durch Drücken von Tab wird das Präfix zu 'Button1' ergänzt.
  • Else: wie Eingabe und fügt das Zeichen zum Quelltexteditor hinzu

Methoden

Wenn der Kursor in einer Klassendefinition steht und Sie die Vervollständigung aufrufen für eine in einer Vorfahren-Klasse definierten Methode, dann werden automatisch die Parameter und das Schlüsselwort 'override' angefügt. Zum Beispiel:

TMainForm = class(TForm)
protected
  mous|
end;

Die Vervollständigung von MouseDown ergibt:

TMainForm = class(TForm)
protected
  procedure MouseDown(Button: TMouseButton; Shift: TShiftState; X,
         Y: Integer); override;
end;

Eigenschaften

property MyInt: integer read |;

Die Bezeichner-Vervollständigung zeigt Ihnen FMyInt und GetMyInt.

property MyInt: integer write |;

Die Bezeichner-Vervollständigung zeigt Ihnen FMyInt und SetMyInt.

Uses-Abschnitt / Unitnamen

In Uses-Abschnitten zeigt die Bezeichner-Vervollständigung die Dateinamen aller Units im Suchpfad. Diese werden immer in Kleinbuchstaben angezeigt (z.B. avl_tree), weil die meisten Units ohnehin kleinbuchstabige Dateinamen haben. Bei der Vervollständigung wird aber die "niedliche" Schreibweise für Dateinamen eingesetzt (z.B. AVL_Tree).

Anweisungen

procedure TMainForm.Button1Click(Sender: TObject);
begin
  ModalRe|;
end;

wird zu:

procedure TMainForm.Button1Click(Sender: TObject);
begin
  ModalResult:=|;
end;

Wortvervollständigung

Die "Wortvervollständigung" wird aufgerufen mit Strg+W. Sie zeigt alle Wörter aus allen derzeit offenen Editoren und kann deshalb auch in Nicht-Pascal-Quelltexten, in Kommentaren und für Schlüsselwörter benutzt werden.

Ansonsten funktioniert sie genau gleich wie die Bezeichner-Vervollständigung.

Zu Include-Anweisung springen

"Zu Include-Anweisung springen" im Menü 'Suchen' der IDE springt zur {$I filename} Anweisung, wo die aktuelle Include-Datei verwendet wird.

Projekt veröffentlichen

Erzeugt eine Kopie des gesamten Projekts. Wenn Sie jemandem einfach die Quellen und Kompilereinstellungen Ihres Codes senden wollen, dann ist diese Funktion Ihr Freund.

Ein normales Projektverzeichnis enthält eine Menge an Informationen. Das meiste davon wird für eine Veröffentlichung nicht benötigt: Die .lpi Datei enthält Sessioninformationen (wie Cursorposition und Lesezeichen geschlossener Units) und das Projektverzeichnis enthält eine Menge von .ppu und .o Dateien und die ausführbare Datei. Um eine .lpi Datei zu erzeugen, die nur die Basisinformationen und nur den Quellen enthält (zusammen mit allen Unterverzeichnissen), verwenden Sie "Projekt veröffentlichen".

Anmerkung: Seit Version 0.9.13 gibt es eine neue Projekteinstellung die es Ihnen erlaubt, Sessioninformationen in einer anderen Datei als der normalen .lpi Datei zu speichern. Diese neue Datei endet mit der .lps Erweiterung und enthält nur Sessioninformationen, was die .lpi Datei viel übersichtlicher macht.

In dem Dialog können Sie den Exclude- und Include-Filter einstellen, und mit dem anschließenden Kommando können Sie den Output in ein einzelnes Archiv komprimieren.

Tipps von Kommentaren

An verschiedenen Stellen zeigt die IDE Tipps für einen Bezeichner an. Beispielsweise, wenn Sie den Mauszeiger über einen Bezeichner im Quelltexteditor bewegen und einige Sekunden warten. Wenn die IDE einen Tipp für einen Bezeichner anzeigt, sucht sie die Deklaration und alle ihre Vorfahren und hält nach Kommentaren und fpdoc-Dateien Ausschau. Es gibt viele Kodierstile und viele Kommentierstile. Um möglichst viele der allgemein üblichen Stile zu unterstützen, benutzt die IDE folgende Heuristik:

Kommentare im Tipp angezeigt

Kommentare vor einer Deklaration, ohne Leerzeile und nicht mit dem <-Zeichen beginnend:

var
  {Comment}
  Identifier: integer;

Kommentare mit dem <-Zeichen gehören zum vorhergehenden Bezeichner.

Kommentare hinter einem Bezeichner in der selben Zeile:

var 
  identifier, // Comment
  other,

Kommentare hinter der Definition in der selben Zeile:

var
  identifier: 
    char; // Comment

Ein Beispiel für das <-Zeichen:

const
  a = 1;
  //< comment for a
  b = 2;
  // comment for c
  c = 3;

Alle drei Kommentartypen werden unterstützt:

  {Comment}(*Comment*)//Comment
  c = 1;

Kommentare, die mit $ und % beginnen, werden ignoriert.

Kommentare, nicht im Tipp angezeigt

Vorlaufende Kommentare, die mit einer Leerzeile abgetrennt werden, werden als unspezifisch für den folgenden Bezeichner angesehen. Beispielsweise wird der Kommentar für den folgenden Klassenheader nicht im Tipp angezeigt:

type
  { TMyClass }
  
  TMyClass = class

Die Kommentare für Klassenheader werden bei der Klassenvervollständigung erzeugt. Sie können dies ausschalten unter Einstellungen / Codetools / Klassenvervollständigung / Header-Kommentar für die Klasse. Falls Sie den Header-Kommentar im Tipp anzeigen wollen, entfernen Sie einfach die Leerzeile.

Der folgende Kommentar wird angezeigt für GL_TRUE, aber nicht für GL_FALSE:

  // Boolean
  GL_TRUE                           = 1;
  GL_FALSE                          = 0;