Version 1.1
Thanks to the CodeBlocks team: Anders F. Bjrklund (afb), Biplab Kumar Modak (biplab), Bartomiej wiecki (byo), Paul o A. Jimenez (ceniza), Koa Chong Gee (cyberkoa), Daniel Orb (daniel2000), Lieven de Cock (killerbot), Yiannis Mandravellos (mandrav), Mispunt (mispunt), Martin Halle (mortenmacy), Jens Lody (jens), Jerome Antoine (dje), Damien Moore (dmoore), Pecan Heber (pecan), Ricardo Garcia (rickg22), Thomas Denk (thomasdenk), tiwag (tiwag) Permission is granted to copy, distribute and/or modify this document under the terms of the GNU Free Documentation License, Version 1.2 or any later version published by the Free Software Foundation.
1 CodeBlocks Projektverwaltung
Die Dokumentation fr Kapitel 3 auf Seite 55 und ?? auf Seite ?? sind ozielle Dokuu mentationen der CodeBlocks Wiki-Seite und nur in englischer Sprache verfgbar. u Die nachfolgende Abbildung zeigt den Aufbau der CodeBlocks Oberche. a
Abbildung 1.1: IDE CodeBlocks Management Diese Fenster enthlt die Ansicht Projects , im nachfolgenden als Projeka tansicht bezeichnet. In dieser werden die in CodeBlocks aktuell geneten Projekte o angezeigt. In dem Management Fenster erhlt man im Reiter Symbols die Anzeige a von Symbolen, Variablen etc. Editor In der obigen Abbildung ist eine Quelle hello.c mit Syntaxhighlighting im Editor genet. o Open les list Zeigt die Liste der im Editor geneten Dateien an, hier hello.c. o CodeSnippets Lsst sich uber das Men View CodeSnippets anzeigen. Hier knnen a u o Textbausteine, Verknpfungen auf Dateien und Urls verwaltet werden. u Logs & others Fenster zur Ausgabe von Suchergebnisse, Logmeldung eines Compilers etc.
CodeBlocks V1.1 Die Statusbar gibt einen Uberblick der folgenden Einstellungen: Vollstndiger Pfad einer im Editor angezeigten Datei. a
1.1 Projektansicht
Im Editor wird das vom Betriebssystem standardmig verwendete Character Ena coding ubernommen und mit der Einstellung default angezeigt. Aktuelle Zeilen- und Spaltnummer der Cursorposition im Editor. Uber die Tastatur eingestellte Modus fr das Einfgen von Text (Insert oder Overu u write). Aktuelle Status einer Datei. Fr eine genderte Datei steht der Eintrag auf Modied u a ansonsten ist dieser Eintrag leer. Die fr eine Datei eingestellte Berechtigung. Eine schreibgeschtzte Datei wird als u u Read only in der Statusbar gekennzeichnet. Im Fenster Open les list werden solche mit einem Schloss als Icon Overlay markiert. Hinweis: Im aktiven Editor kann uber das Kontextmen Properties im Reiter u General die Option File is read-only aktiviert werden. Dies bewirkt das die Datei nur innerhalb CodeBlocks schreibgeschtzt ist, u jedoch bleibt die Lese- und Schreibberechtigung auf der Festplatte unverndert. a Falls CodeBlocks mit der Kommandozeilenoption --personality=<profile> gestartet wird, steht in der Statusbar das aktuell verwendete Prol, ansonsten wird hier default angezeigt. Die Einstellungen von CodeBlocks werden in der gleichnamigen Kongurationsdatei <personality>.conf gespeichert. CodeBlocks bietet eine sehr exible und umfassende Projektverwaltung. Der folgende Text geht nur auf einige Besonderheiten der Projektverwaltung ein.
1.1 Projektansicht
In CodeBlocks werden Quellen und die Einstellungen fr den Builtprozess in einer Projektu datei <name>.cbp gespeichert. Ein Projekt besteht typischerweise aus C/C++ Quellen und zugehrige Header Dateien. Ein neues Projekt legen Sie am einfachsten an, indem Sie o das Men File Project ausfhren und einen Wizard auswhlen. Anschlieend knnen u u a o Sie im Management Fenster uber das Kontextmen Add les Dateien zum Projekt hinu zufgen. In CodeBlocks werden die Projektdateien abhngig von ihrer Dateiendung in u a Kategorien verwalten. Die voreingestellen Kategorien sind fr u Sources Unter der Kategorie Sources werden Quellen z.B. mit den Endungen *.c;*.cpp; aufgelistet. ASM Sources Unter der Kategorie ASM Sources werden Quellen z.B. mit den Endungen *.s;*.S;*.ss;*.asm aufgelistet. Headers Unter der Kategorie Headers werden Dateien z.B. mit den Endungen *.h; angezeigt. Codeblocks 2
CodeBlocks V1.1
Resources Unter der Kategorie Resources werden z.B. Dateien *.res;*.xrc; fr die u Beschreibung von Layout von wxWidgets Fenster gelistet. Fr die Anzeigen dieser u Dateitypen dient im Manangement Fenster der Reiter Resources. Die Einstellungen fr Typen und Kategorien von Dateien knnen uber das Kontextu o men Project tree Edit le types & categories angepasst werden. Dabei knnen u o auch eigene Kategorien fr Dateiendungen angelegt werden. Wenn Sie z.B. Linkerskripte u mit der Endung *.ld unter der Kategorie Linkerscript anzeigen mchten, legen Sie o einfach eine neue Kategorie an. Hinweis: Wenn Sie im Kontextmen Project tree Categorize by le types u deaktivieren, wird die Anzeige in Kategorien aufgehoben und die Dateien erscheinen wie sie im Dateisystem abgelegt sind.
1.3 Projektvorlagen
CodeBlocks wird mit einer Vielzahl von Projektvorlagen ausgeliefert, die beim Anlegen eines neuen Projektes angezeigt werden. Es ist aber auch mglich, eigene Vorlagen zu speio chern und somit eigene Vorgaben fr Compilerschalter, wie zu verwendete Optimierung, u maschinenspezische Schalter etc. in Vorlagen zusammenzufassen. Diese werden im Verzeichnis Dokumente und Einstellungen\<user>\Anwendungsdaten\codeblocks\UserTemplates abgelegt. Wenn die Vorlagen fr alle Benutzer zugnglich sein sollen, mssen die Vorlau a u gen in zugehriges Verzeichnis der CodeBlocks Installation kopiert werden. Diese Vorlagen o erscheinen dann beim nchsten Start von CodeBlocks unter New Project User a templates . Hinweis: Die verfgbaren Vorlagen im Project Wizard knnen durch Auswahl u o mit der rechten Maustaste bearbeitet werden.
CodeBlocks V1.1
Codeblocks
CodeBlocks V1.1
Ein weiteres Beispiel fr ein Postbuilt Step kann die Archivierung eines Projektes sein. u Hierzu erstellen Sie ein Build Target Archive und tragen im Postbuilt Step folgende Anweisung ein
zip -j9 $(PROJECT_NAME)_$(TODAY).zip src h obj $(PROJECT_NAME).cbp
Mit diesem Befehl wird das aktive Projekt und seine Quellen, Header und Objekte als Zip-Datei gepackt. Dabei werden uber die Built-in Variablen $(PROJECT_NAME) und $(TODAY), der Projektname und das aktuelle Datum extrahiert (siehe Abschnitt 3.2 auf Seite 56). Im Verzeichnis des Projektes liegt dann nach Ausfhren des Targets Archive u die gepackte Datei. In dem Verzeichnis share/codeblocks/scripts nden Sie einige Beispiele fr Skripte. u Ein Skript kann uber das Men Settings Scripting hinzugefgt und in ein Men einu u u u u getragen werden. Wenn Sie ein Skript z.B. make dist uber ein Men ausfhren, werden alle Dateien, die zum einem aktiven Projekt gehren in ein Archiv <project>.tar.gz o komprimiert.
CodeBlocks V1.1
Dabei sind die CodeBlocks Variablen durch $ gekennzeichnet (siehe Abschnitt 3.4 auf Seite 60). Diese werden automatisch ersetzt, so dass Sie lediglich die Assembleroption <asopt> durch Ihre Einstellungen ersetzen brauchen.
Codeblocks
CodeBlocks V1.1
1.10.2 Abbreviation
Durch Denition von Abkrzung in CodeBlocks kann einiges an Schreibarbeit und Zeit u gespart werden. Hierzu werden in Settings Editor sogenannte Abbreviations unter dem Namen <name> angelegt, die uber das Tastenkrzel Ctrl-J aufgerufen werden (siehe u Abbildung 1.3 auf Seite 7).
Abbildung 1.3: Denition von Abkrzungen u Durch Einfgen von Variablen $(NAME) in den Abkrzungen ist auch eine Parametrisieu u rung mglich. o
#ifndef $(Guard token) #define $(Guard token) #endif // $(Guard token)
Bei Aufruf der Abkrzung <name> im Quelltext und Ausfhren von Ctrl-J, wird der u u Inhalt der Variablen abgefragt und eingefgt. u
1.10.3 Personalities
CodeBlocks Einstellungen werden als Anwendungsdaten im Verzeichnis codeblocks in einer Datei <user>.conf gespeichert. Diese Kongurationsdatei enthlt Informationen a wie beispielsweise zuletzt genete Projekte, Einstellungen fr Editor, Anzeige von Symo u bolleisten etc. Standardmig ist die Personality default eingestellt, so dass die Kona guration in der Datei default.conf abgelegt ist. Wenn CodeBlocks mit dem Parameter --personality=myuser in der Kommandozeile aufgerufen wird, werden die Einstellungen
Codeblocks
CodeBlocks V1.1
in der Datei myuser.conf gespeichert. Falls das Prol nicht bereits existiert, wird es automatisch angelegt. Durch diese Vorgehensweise knnen fr unterschiedliche durchzufhreno u u de Arbeitsschritte auch zugehrige Prole gespeichert werden. Wenn Sie CodeBlocks mit o dem zustzlichen Parameter --personality=ask starten erscheint ein Auswahldialog fr a u die verfgbaren Prole. u Hinweis: Der Name des aktuell verwendeten Prols/Personality wird rechts in der Statusbar angezeigt.
1.10.4 Kongurationsdateien
Die Einstellungen fr CodeBlocks werden im Prol default.conf im Ordner codeblocks u in Ihren Anwendungsdaten gespeichert. Bei Verwendung von personalities (siehe Unterabschnitt 1.10.3 auf Seite 7 werden die Konguration in der Datei <personality>.conf abgelegt. Mit dem Werkzeug cb share conf, aus dem CodeBlocks Installationsverzeichnis, knnen o diese Einstellungen verwaltet und gesichert werden. Falls Sie Standardeinstellung fr mehrere Benutzer eines PCs vorgeben mchten, muss die u o Kongurationsdatei default.conf im Ordner \Dokumente und Einstellungen\Default User\Anwendungsdaten\codeblocks abgelegt sein. Beim ersten Start von CodeBlocks werden die Voreinstellungen aus Default User in die Anwendungsdaten der aktuellen Benutzers kopiert. Zur Erzeugung einer portablen Version von CodeBlocks auf einem USB-Stick gehen Sie wie folgt vor. Kopieren Sie die CodeBlocks Installation auf einen USB-Stick und legen Sie die Kongurationsdatei default.conf in dieses Verzeichnis. Die Konguration wird als globale Einstellung verwendet. Bitte achten Sie darauf, dass die Datei schreibbar sein muss, damit Anderungen in der Konguration auch gespeichert werden knnen. o
CodeBlocks V1.1
Abbildung 1.4: Suche nach Dateien 2. Umschalten zwischen Quelle und Header uber Kontextmen Swap header/source u 3. Markieren eines Begries z.B. eines Denes in einer Datei und Aufruf des Kontextmen Find declaration u
Abbildung 1.5: Onen einer Header Datei CodeBlocks bietet verschiedene Mglichkeiten fr die Suche in einer Datei oder in Vero u zeichnissen. Mit dem Search Find (Ctrl-F) oder Find in Files (Ctrl-Shift-F) net o sich der Dialog fr die Suche. u Eine weitere komfortable Funktion bietet das Tastenkrzel Alt-G und Ctrl-Alt-G. Der sich u o nende Dialog erlaubt die Auswahl von Dateien/Funktionen und springt anschlieend an die Implementierung der Funktion (siehe Abbildung 1.6 auf Seite 10) bzw. nete die o ausgewhlte Datei. Als Eingabe werden auf Wildcards oder ? etc. fr eine inkrementelle a u Suche untersttzt. u Hinweis: Mit dem Tastenkrzel Ctrl-PAGEUP springen Sie an die vorherige u Funktion und mit Ctrl-PAGEDOWN zur nchsten Funktion. a Wenn Sie sich im Editor Fenster benden, net sich mit Ctrl-Tab ein zustzliches Open o a Files Dialog und es kann zwischen den Eintrgen der zu nenden Dateien gewechselt a o werden. Bei gedrckter Ctrl-Taste kann eine Auswahl auf unterschiedliche Weise erfolgen: u Codeblocks 9
CodeBlocks V1.1
Abbildung 1.6: Suche nach Funktionen 1. Mit der linken Maustaste einen Eintrag anklicken und es net sich die Datei. o 2. Bettigen der Tab-Taste wechselt zwischen den Eintrgen. Durch Loslassen der Ctrla a Taste wird die ausgewhlte Datei genet. a o 3. Wenn die Maus uber die Eintrge bewegt werden, dann erscheint die aktuelle Ausa wahl farblich hervorgehoben. Beim Loslassen wird die ausgewhlte Datei genet. a o 4. Wenn der Mauszeiger auerhalb der farblich Hervorhebung steht, dann kann uber das Mausrad eine Auswahl getroen werden. Beim Loslassen der Crtl-Taste wird die ausgewhlte Datei genet. a o Eine huge Arbeitsweise bei der Entwicklung von Software ist jedoch, dass man sich a durch ein Satz von Funktion hangelt, die in unterschiedlichen Dateien implementiert sind. Durch das Plugin Browse Tracker zeigt mit dem Fenster Browsed Tabs eine Liste in der Reihenfolge wie Dateien selektiert wurden. Somit knnen Sie komfortabel zwischen den o Aufrufen navigieren (siehe Abschnitt 2.8 auf Seite 40). In CodeBlocks aktivieren Sie die Anzeige von Zeilennummern in Settings General Settings im Feld Show line numbers. Mit dem Tastenkrzel Ctrl-G oder uber das u Men Search Goto line springen Sie an die gewnschte Zeile. u u Hinweis: Sie knnen auch im Editor einen Begri mit gedrckter Ctrl Taste o u markieren und dann uber das Kontextmen nach diesem Begri z.B. u in Goolge suchen.
1.10.6 Symbolansicht
Fr das Navigieren uber Funktionen oder Variablen bietet das Management Fenster in u CodeBlocks eine Baumansicht fr Symbole von C/C++ Quellen. Dabei lsst sicht der u a Gltigkeitsbereich (Scope) der Ansicht auf die aktuelle Datei oder Projekt oder den geu samten Arbeitsbereich einstellen. Codeblocks 10
Wenn Sie einen Suchbegri bzw. Symbolnamen in die Eingabemaske Search des Symbol Browsers eingeben, erhalten Sie, bei vorhandenen Suchtreern, eine gelterte Ansicht von Symbolen. Fr die Kategorien der Symbole existieren folgende Kategorien. u Global functions Listet die Implementierung von globalen Funktionen. Global typedefs Listet die Verwendung von typedef Denitionen. Global variables Zeigt die Symbole von globalen Variablen an. Preprocessor symbols Auistung der mit #dene erzeugten Prprozessor Direktiven. a Global macros Listet Makros von Prprozessor Direktiven auf. a
Abbildung 1.7: Symbolansicht Strukturen und Klassen werden unterhalb im bottom tree angezeigt und die Sortierung kann uber das Kontextmen gendert werden. Wenn eine Kategorie mit der Maus anu a gewhlt wird, erscheinen die gefundenen Symbole in dem unteren Teil des Fensters (siehe a Codeblocks 11
CodeBlocks V1.1
Abbildung 1.7 auf Seite 11). Ein Doppelklick auf das Symbol net die Datei, wo das o Symbol deniert bzw. die Funktion implementiert ist und springt an die zugehrige Zeile. o Die Symbolansicht wird beim Speichern einer Datei aktualisiert. Eine Auto-Refresh des Symbolbrowsers ohne Speichern ist uber das Men Settings Editor Code Compleu tion aktivierbar (siehe Abbildung 1.8 auf Seite 12). Bei Projekten mit vielen Symbolen wird die Performance innerhalb CodeBlocks beeintrchtgt. a
Hinweis: Im Editor knnen Sie uber das Kontextmen Insert Class method o u declaration implementation bzw. All class methods without implementation sich auch die Liste der Klassen anzeigen lassen.
CodeBlocks bietet auch einen Embedded HTML Viewer, hiermit knnen einfache HTMLo Dateien in CodeBlocks angezeigt und fr Suchen genutzt werden. Kongurieren Sie einu fach den Pfad der HTML-Datei, die durchsucht werden soll und aktivieren Sie die Option Open this le with embedded help viewer in dem Men Settings Environment u Help Files .
Codeblocks
12
CodeBlocks V1.1
Abbildung 1.10: Embedded HTML Viewer Hinweis: Wenn Sie eine HTML-Datei im File Explorer mit einem Doppelklick onen (siehe Abschnitt 2.7 auf Seite 36) dann wird der Embedded Html Viewer gestartet, solange fr HTML Dateien keine andere Zuu ordnung im le extension handler vorgenommen wurde.
Codeblocks
13
CodeBlocks V1.1
Abbildung 1.11: Verfolgen von Anderungen Diese Feature kann unter Settings Editor Margins and caret mit der Checkbox Use Changebar aktiviert bzw. deaktiviert werden. Hinweis: Wenn eine genderte Datei geschlossen wird, geht die Anderungsina formation fr Undo/Redo und die Revisionsbalken verloren. Uber das u Men Edit Clear changes history oder das zugehrige Kontextu o men kann auch bei geneter Datei die Anderungshistorie gelscht u o o werden.
CodeBlocks V1.1
Exchange) und unter anderen Betriebssystemen auf eine TCP Kommunikation zwischen den Anwendungen abgebildet. Uber diese Schnittstelle knnen an CodeBlocks Kommandos mit der folgenden Syntax o weitergegeben werden.
[<command>("<parameter>")]
wird der Parameter, hier die Datei mit absolutem Pfad, innerhalb einer CodeBlocks Instanz genet oder bei Bedarf eine erste Instanz o gestartet.
OpenLine
Das Kommando net eine Datei mit spezizierter Zeilennummer in o einer CodeBlocks Instanz. Diese Zeilennummer wird mit : line angegeben.
[OpenLine("d:\temp\test.txt:10")]
Raise
Setzt den Fokus auf die CodeBlocks Instanz. Hier darf kein Parameter angegeben werden.
CodeBlocks V1.1
Abbildung 1.12: Umgebungsvariablen Der Zugri und der Gltigkeitkeitbereich auf die hier erstellten Umgebungsvariablen ist u auf CodeBlocks begrenzt. Sie knnen diese Umgebungsvariablen wie auch andere Codeo Blocks Variablen uber $(NAME) expandieren. Hinweis: Eine Konguration von Umgebungsvariable lsst sich pro Projekt im a Kontextmen Properties im Reiter EnvVars options selektieren. u Beispiel Sie knnen die verwendete Umgebung in einem postbuild Step (siehe Abschnitt 1.6 auf o Seite 4) in einer Datei <project>.env schreiben und zu Ihrem Projekt archivieren.
cmd /c echo \%PATH\% > project.env
CodeBlocks V1.1
Damit der Anwender nicht stndig mit dem Onen und Schlieen von Fenstern, Symbola leisten etc. beschftigt ist, bietet CodeBlocks einen Mechanismus um unterschiedliche Pera spektiven zu speichern bzw. diese umzuschalten. Uber das Men View Perspectives u Save current und Eingabe eines Namens <name> wird eine Perspektive gespeichert. Uber Settings Editor Keyboard shortcuts View Perspectives <name> kann ein Tastenkrzel hierfr angegeben werden. Durch diese Vorgehensweise knnen Sie u u o nun einfach zwischen den Ansichten uber Ihre Tastenkrzel wechseln. u Hinweis: Ein weiteres Anwendungsbeispiel ist das Editieren einer Datei im Full Screen Modus ohne Symbolleisten. Hierfr knnen Sie sich auch eine u o Perspektive z.B. Full anlegen und ein Tastenkrzel vergeben. u
Codeblocks
17
CodeBlocks V1.1
Abbildung 1.13: Einstellung von Detailinformationen Hinweis: Mit dem Tastenkrzel Ctrl-Numepad-/ oder mit Edit Special u commands Zoom Reset knnen Sie auf die ursprngliche o u Schriftgre umschalten. o
CodeBlocks V1.1
1. Mit der linken Maustaste kann ein Text innerhalb des Editors selektiert werden und dann die Maustaste gelst werden. Nun kann der Benutzer mit dem Mausrad o innerhalb des aktiven Editors scrollen und durch Bettigen der mittleren Maustaste, a wird der ehemals selektierte Text an die aktuelle Cursorposition eingefgt. Dieses u Verhalten funktioniert pro Datei und die Selektion kann als Zwischenablage pro Datei verstanden werden. 2. Durch Halten der ALT Taste wird der Block-Select Modus aktiviert und ein Rechteck kann mit der linken Maustaste aufgezogen werden und dann kopiert bzw. eingefgt weden. Dies ist zum Beispiel ntzlich, wenn nur einige Spalten eines Array u u markiert und kopiert werden sollen. 3. Im Men Settings Editor Margins und Caret knnen sogenannte Virtual u o Spaces aktiviert werden. Diese Option bewirkt, dass im Block Select Modus eine Auswahl auch innerhalb einer leeren Zeilen beginnen oder enden kann. 4. Im Men Settings Editor Margins und Caret kann Multiple Selection u aktiviert werden. Bei gedrckter Crtl-Taste knnen dann mit der linken Maustaste u o mehrere Textpassagen im Editor selektiert werden. Die Selektionen knnen mit Ctrlo C bzw. Ctrl-X in der Zwischenablage hintereinander angehngt und mit Ctrl-V an a die gewnschte Stelle eingefgt werden. Zudem kann im multiple Selection Modus u u die Option Enable typing (and deleting) aktiviert werden. Dies kann z.B. ntzlich u sein, wenn Sie an mehreren Stellen eine Prprozessor Direktive wie #ifdef einfgen a u wollen oder z.B. ein Text an mehreren Stellen uberschreiben oder ersetzen wollen. Hinweis: Beachten Sie, dass die meisten Linux Fenstermanager diese Tastenkombination fr das Verschieben von Fenster vordenieren. Deshalb u muss dieses Verhalten des Fenstermanager gendert werden, damit a der Block select mode unter Linux funktioniert.
Codeblocks
19
CodeBlocks V1.1
Neben dem Folding fr Funktionen kann die Funktionalitt auch fr Prprozessor Direku a u a tiven eingestellt werden. Aktivieren Sie hierfr die Option Fold preprocessor commands u im Men Settings Editor unter dem Eintrag Folding. u Eine weitere Mglichkeit ist benutzerdenierte Folding Punkte zu denieren, indem ein o Kommentarzeichen durch eine genete Klammer den Anfang und ein Kommentar mit o schlieender Klammer das Ende markiert.
//{ code with user defined folding //}
Hinweis: Bei eingeschaltetem Folding passiert es hug, dass bei engem Seia tenrand der Anwender anstatt die gewnschte Zeile zu markieren, u den Folding point selektiert. In diesem Modus ist es deshalb ratsam die Zeilennummern im Editor einzublenden und dann mit der linken Maustaste in den linken Seitenrand neben der Anzeige der Zeilennummern eine oder mehrere Zeile zu markieren.
CodeBlocks V1.1
Sie entweder den absoluten Pfad zur Bibliothek durchsuchen oder nur den Namen ohne den Prex lib und die Dateiendung angeben. Beispiel Fr eine Bibliothek <path>\libs\lib<name>.a geben Sie einfach <name> an. Der u Linker mit den jeweiligen Suchpfaden fr die Bibliotheken bindet diese dann korrekt ein. u Hinweis: Eine weitere Mglichkeit wie Sie Bibliotheken einbinden knnen, beo o schreibt Abschnitt 2.10 auf Seite 41.
1.11.15 Autosave
CodeBlocks bietet die Mglichkeit Projekte und Quelldateien automatisch zu speichern o bzw. eine Sicherungskopie anzulegen. Diese Funktionalitt wird im Men Settings Environment a u Autosave eingestellt. Dabei sollte als Save to .save le als Methode fr das Erstellen u einer Sicherungskopie eingestellt werden.
Codeblocks
21
CodeBlocks V1.1
<filename>
Species the project *.cbp lename or workspace *.workspace lename. For instance, <lename> may be project.cbp. Place this argument at the end of the command line, just before the output redirection if there is any.
--file=<filename>[:line] Open le in Code::Blocks and optionally jump to a specic line. /h, --help Shows a help message regarding the command line arguments.
/na, --no-check-associations Dont perform any le association checks (Windows only). /nd, --no-dde /ni, --no-ipc Dont start a DDE server (Windows only). Dont start an IPC server (Linux and Mac only).
/ns, --no-splash-screen Hides the splash screen while the application is loading. /d, --debug-log Display the debug log of the application. --prefix=<str> Sets the shared data directory prex. /p, --personality=<str>, --profile=<str> Sets the personality to use. You can use ask as the parameter to list all available personalities. --rebuild Clean and build the project or workspace.
--build Build the project or workspace. --target=<str> Sets target for batch build. For example --target=Release. --no-batch-window-close Keeps the batch log window visible after the batch build is completed. --batch-build-notify Shows a message after the batch build is completed. --safe-mode Alle Plugins werden beim Start deaktiviert.
> <build log file> Placed in the very last position of the command line, this may be used to redirect standard output to log le. This is not a codeblock option as such, but just a standard DOS/*nix shell output redirection. Codeblocks 22
CodeBlocks V1.1
1.13 Shortcuts
1.13 Shortcuts
Auch wenn man eine IDE wie CodeBlocks uberwiegend mit der Maus bedient, erweisen sich dennoch Tastenkombinationen immer wieder als hilfreich, um die Arbeit zu vereinfachen und zu beschleunigen. In nachstehender Tabelle sind einige verfgbare Tastenkomu binationen zusammengefasst.
1.13.1 Editor
Function Undo last action Redo last action Swap header / source Comment highlighted code Uncomment highlighted code Auto-complete / Abbreviations Toggle bookmark Goto previous bookmark Goto next bookmark Shortcut Key Ctrl-Z Ctrl-Shift-Z F11 Ctrl-Shift-C Ctrl-Shift-X Ctrl-Space/Ctrl-J Ctrl-B Alt-PgUp Alt-PgDown
This is a list of shortcuts provided by the CodeBlocks editor component. These shortcuts cannot be rebound. Create or delete a bookmark Go to next bookmark Select to next bookmark Find selection. Find selection backwards. Find matching preprocessor conditional, skipping nested ones. Ctrl-F2 F2 Alt-F2 Ctrl-F3 Ctrl-Shift-F3 Ctrl-K
1.13.2 Files
Function New le or project Open existing le or project Save current le Save all les Close current le Close all les Shortcut Key Ctrl-N Ctrl-O Ctrl-S Ctrl-Shift-S Ctrl-F4/Ctrl-W Ctrl-Shift-F4/Ctrl-Shift-W
1.13.3 View
Function Show / hide Messages pane Show / hide Management pane Activate prior (in Project tree) Activate next (in Project tree) Shortcut Key F2 Shift-F2 Alt-F5 Alt-F6
Codeblocks
23
CodeBlocks V1.1
1.13 Shortcuts
1.13.4 Search
Function Find Find next Find previous Find in les Replace Replace in les Goto line Goto next changed line Goto previous changed line Goto le Goto function Goto previous function Goto next function Goto declaration Goto implementation Open include le Shortcut Key Ctrl-F F3 Shift-F3 Crtl-Shift-F Ctrl-R Ctrl-Shift-R Ctrl-G Ctrl-F3 Ctrl-Shift-F3 Alt-G Ctrl-Alt-G Ctrl-PgUp Ctrl-PgDn Ctrl-Shift-. Ctrl-. Ctrl-Alt-.
1.13.5 Build
Function Build Compile current le Run Build and Run Rebuild Shortcut Key Ctrl-F9 Ctrl-Shift-F9 Ctrl-F10 F9 Ctrl-F11
Codeblocks
24
2 Plugins
2.1 Astyle
Artistic Style dient dem Einrcken, Formatieren und Verschnern fr C, C++, C# u o u Quellen. Es kann verwendet werden um unterschiedliche Coding Rules fr CodeBlocks u einzustellen.
Abbildung 2.1: Formatierung fr Quellcode u Wenn Quellen eingerckt werden, tendieren Programmierer dazu sowohl Leerzeichen als u auch Tabulatoren einzusetzen, um die gewnschte Einrckung zu erzielen. Darberhinaus u u u gibt es auch Editoren die standardmig Tabulatoren durch eine feste Anzahl von Leera zeichen ersetzen. Andere Editoren versuchen den Code durch Einfgen von White space u lesbarer zu machen selbst wenn der Code Tabulatoren enthlt. a Da die Anzeige der Leerzeichen fr jeden Tabulator durch die Einstellungen im Editor u bestimmt ist, wirft dies immer ein Problem auf, wenn Programmierer unterschiedliche Editoren verwenden. Selbst bei grter Sorgfalt fr die Formatierung der Quelle kann das o u Editieren durch andere Programmieren mit unterschiedlichen Editoren oder Einstellungen schnell Problemen verursachen. Um diesen Problem Rechnung zu tragen, wurde Artistic Style entwickelt - ein Filter, der automatisch Ihre C / C++ / C# einrckt und formatiert. u
2.2 CodeSnippets
Durch Kopieren von Code z.B aus dem Internet oder aus einem Manual wird in CodeBlocks der Code automatisch an die ausgewhlten a Coding-Rules angepasst, indem Sie den Text markieren und das Plugin uber das Men Plugins Source code formatter ausfhren. u u
2.2 CodeSnippets
Das Plugin CodeSnippets ermglicht es Textbausteine und Verknpfungen auf Dateien in o u einer Baumansicht nach Kategorien zu strukturieren. Die Bausteine dienen dazu, hug a verwendete Dateien oder Konstrukte in Textbausteine abzulegen und zentral zu verwalten. Stellen Sie sich vor eine Reihe von hug verwendeten Quelldateien sind im Dateisystem in a unterschiedlichen Ordnern abgelegt. Im Fenster CodeSnippets knnen Sie nun Kategorien o und darunter Verknpfungen auf die gewnschten Dateien erstellen. Damit knnen Sie u u o den Zugri auf die Dateien unabhngig von der Ablage im Dateisystem verwalten und a ohne das Dateisystem zu durchsuchen schnell zwischen diesen Dateien navigieren. Hinweis: Sie knnen auch CodeBlocks Variablen oder Umgebungsvaraiblen vero wenden, um Links im CodeSnippets Browser zu parametrisieren z.B. $(VARNAME)/name.pdf. Die Liste der Textbausteine und Verknpfungen knnen im CodeSnippets Fenster mit u o der rechten Maustaste uber das Kontextmen Save Index gespeichert werden. Die dabei u erzeugte Datei codesnippets.xml bendet sich anschlieend in Ihren Dokumente und Einstellungen\Anwendungsdaten im Ordner codeblocks. Unter Linux wird diese Information im HOME-Verzeichnis im Ordner .codeblocks abgelegt. Die Kongurationsdateien von CodeBlocks werden beim nchsten Start geladen. Falls Sie den Inhalt von a CodeSnippets an einen anderen Ort speichern mchten, selektieren Sie den Eintrag Save o Index As. Zum Laden dieser Datei whlen Sie beim nchsten Start von CodeBlocksLoad a a Index File oder stellen das Verzeichnis in dem Kontextmen Settings unter Snippet u Folder ein. Diese Einstellungen werden in der zugehrigen Datei codesnippets.ini in o den Anwendungsdaten hinterlegt. Das Einfgen einer Kategorie geschieht uber das Men Add SubCategory. In einer Kau u tegorie knnen Snippets (Textbausteine) oder File Links (Verknpfungen) liegen. Ein o u Textbaustein wird mit dem Kontextmen uber Add Snippet angelegt. Indem Sie einen u Text im CodeBlocks Editor markieren und anschlieend bei gedrckter linker Maustaste u per Drag and Drop auf den Textbaustein ziehen, wird der Inhalt in den Textbaustein eingefgt. Wenn Sie einen selektierten Text auf eine Kategorie ziehen wird in diesem Ordu ner automatisch ein Textbaustein mit dem Namen New snippet erzeugt und es net o sich der Properties Dialog. Durch einen Doppelklick auf den neu eingefgten Eintrag oder u durch Auswahl von Edit Text net sich ein eigenstndiger Editor zum Bearbeiten des o a Inhaltes. Die Ausgabe eines Textbausteines in CodeBlocks erfolgt uber das Kontextmen Apply u oder durch Drag und Drop in den Editor. Die Inhalte eines Snippets knnen auch in o Codeblocks 26
CodeBlocks V1.1
2.2 CodeSnippets
Abbildung 2.2: Bearbeiten eines Textbausteins andere Anwendungen gezogen werden. Im CodeSnippets Browser knnen Sie auch per o Drag and Drop einen Eintrag in eine andere Kategorie kopieren. Textbausteine sind darberhinaus auch uber Variablen <name>, die uber $(name) zuu gegrien werden, parametrisierbar (siehe Abbildung 2.2 auf Seite 27). Die Abfrage fr u die Werte der Variablen erfolgt uber ein Eingabefeld, wenn der Textbaustein mit dem Kontextmen Apply aufgerufen wird. u Neben den Textbausteinen knnen auch Verknpfungen auf Dateien angelegt werden. o u Wenn Sie zuvor einen Textbaustein angelegt haben und anschlieend das Kontextmen Prou perties auswhlen, selektieren Sie mit der Schaltche Link target das Ziel der Vera a knpfung. Eine Verknpfung kann auch uber das Kontextmen Convert to FileLink eru u u zeugt werden. Dieser Schritt wandelt den Textbaustein automatisch in eine Verknpfung u auf eine Datei um. In CodeSnippets werden Textbausteine mit einem T-Symbol und Verknpfungen auf eine Datei mit einen F-Symbol und Urls mit einem U-Symbol gekennu zeichnet. Falls Sie die in Codesnippets markierte Datei (Verknpfung) nen mchten u o o selektieren Sie im Kontextmen Open File oder halten Sie die Alt Taste gedrckt und u u machen ein Doppelklick auf die Datei. Hinweis: In Textbausteine knnen auch Urls angegeben werden z.B. o http://www.codeblocks.org. Die Url kann wahlweise uber das Kon textmen Open Url oder per Drag and Drop in Ihrem gewohnten u Webbrowser genet werden. o Falls Sie diese Einstellung vorgenommen haben, dann wird wenn Sie z.B. einen Verknpfung auf eine pdf-Datei aus der Codesnippets Ansicht nen automatisch ein pdfu o Viewer gestartet. Dieses Vorgehen ermglicht dem Benutzer Dateien, die uber das Netzo werk verteilt liegen, wie z.B. CAD Daten, Schaltplne, Dokumentation etc. als Vera knpfung einfach uber die gewohnten Anwendungen zuzugreifen. Der Inhalt der Cou desnippets wird in der Datei codesnippets.xml und die Konguration in der Datei codesnippets.ini in Ihren Anwendungsdaten gespeichert. In dieser ini Datei wird z.B. der Ablageort der Datei codesnippets.xml hinterlegt.
CodeBlocks untersttzt die Verwendung von unterschiedlichen Prolen. Diese werden als u personalities bezeichnet. Wenn Sie CodeBlocks mit der Kommandozeilen Option --personality=<prof starten, wird entweder ein neues angelegt oder ein existierendes Prol verwendet. Die Codeblocks 27
CodeBlocks V1.1
2.2 CodeSnippets
Einstellungen werden dann statt in default.conf in der Datei <personality>.conf in den Anwendungsdaten gespeichert. Das Plugin Codesnippets speichert seine Einstellungen dann in der Datei <personality>.codesnippets.ini. Wenn nun Sie in den Settings von Codesnippets uber Load Index File einen neuen Inhalt <name.xml> laden, wird dies in der zugehrigen ini Datei hinterlegt. Der Vorteil von dieser Vorgehensweise ist, dass o Sie zu unterschiedlichen Prolen auch unterschiedliche Kongurationen fr Textbausteine u und Verknpfungen verwalten knnen. u o Fr das Navigieren zwischen den Kategorien und Snippets bietet das Plugin eine zustzu a liche Suchfunktion. Hierbei lsst sich auch der Gltigkeitsbereich (Scope) fr die Suche a u u auf Snippets, Categories oder Snippets and Categories einstellen. Durch Eingabe des gewnschten Suchbegries wird automatisch der zugehrige Eintrag in der Ansicht ausu o gewhlt. Die Abbildung 2.3 auf Seite 28 zeigt eine typische Ansicht im CodeSnippets a Fenster.
Hinweis: Bei Verwendung von umfangreichen Textbausteine sollte deren Inhalt uber Convert to File Link in Dateien ausgelagert werden, um die Speicherauslastung im System zu reduzieren. Beim Lschen von o Textbausteine und Verknpfungen werden diese in den Ordner .trash u verschoben bzw. bei gedrckter Shift-Taste direkt gelscht. u o
Codeblocks
28
CodeBlocks V1.1
Wird der Suchbegri in der aktiven Datei jedoch nicht gefunden, wird dies durch rotes Hinterlegen der Suchmaske signalisiert. ESC Verlsst den Incremental Search Modus. a ALT-DELETE Lscht den Inhalt fr die Eingabe von Incremental Search. o u Die Icons in der Werkzeugleiste von Incremental Search sind wie folgt zu verstehen: Lschen des Textes innerhalb der Suchmaske der Incremental Search Werkzeugleiste. o , Navigation zwischen den Vorkommen eines Suchbegries. Dieser Knopf bewirkt, dass nicht nur der aktuelle gefundene Suchbegri im Editor sondern auch weitere Vorkommnisse farblich hervorgehoben werden. Mit der Aktivierung dieser Option wird nur innerhalb eines selektierten Textes im Codeblocks 29
CodeBlocks V1.1 Editor gesucht. Bewirkt, dass die Suche von Gro-/Kleinschreibung abhngt. a Der Suchbegri wird als regulrer Ausdruck interpretiert. a Hinweis:
Die standardmigen Einstellungen dieser Werkzeugleiste sind in Seta tings Editor Incremental Search kongurierbar.
Abbildung 2.4: Anzeige der ToDo List Hinweis: Die To-Do Liste kann auch direkt in der Message Console angezeigt werden, indem Sie die Einstellung Include the To-Do list in the message pane im Men Settings Environment auswhlen. u a Ein Todo lsst sich bei geneten Quellen in CodeBlocks uber die rechte Maustaste Add a o To-Do item hinzufgen. Im Quellcode wird ein entsprechender Kommentar an der ausu gewhlten Quellzeile eingefgt. a u
// TODO (user#1#): add new dialog for next release
Beim Hinzufgen eines To-Do erhalten Sie einen Eingabedialog mit folgenden Einstellunu gen (siehe Abbildung 2.5 auf Seite 31). Codeblocks 30
CodeBlocks V1.1
Abbildung 2.5: Dialog fr Eingabe von ToDo u User Username <user> im Betriebssystem. Hierbei knnen auch Aufgaben fr andere o u Benutzer angelegt werden. Dabei muss der zugehrige Benutzername uber Add new o user hinzugefgt werden. Die Zuordnung eines Todo geschieht dann uber die Ausu wahl der unter User aufgelisteten Eintrge. a Hinweis: Beachten Sie, dass die User nichts mit den in CodeBlocks verwendeten Personalities zu tun haben. Type Standardmig ist der Typ auf Todo eingestellt. a Priority Die Wichtigkeit von Aufgaben knnen in CodeBlocks durch Prioritten (Werteo a bereich: 1 - 9) gewichtet werden. Position Einstellung ob der Kommentar vor, nach oder exakt an der Stelle des aktuell bendlichen Cursor eingefgt werden soll. u Comment Style Auswahl der Formatierung fr Kommentare (zum Beispiel doxygen). u
CodeBlocks V1.1
html Ein textbasiertes Format, das in einem Web-Browser oder Anwendungen zur Textverarbeitung angezeigt werden kann. rtf Das Rich Text Format ist ein textbasiertes Format, das sich in Programmen zur Textverarbeitung wie Word oder OpenOce nen lsst. o a odt Open Document Text Format ist ein standardisiertes Format, dass von Sun und OReilly festgelegt wurde. Dieses Format kann von Word, OpenOce und anderen Textverarbeitungsprogrammen eingelesen werden. pdf Das Portable Document Format kann mit Anwendungen wie Acrobat Reader genet o werden.
2.6.1 Features
ThreadSearch plugin bietet folgende Funktionalitt a Mehrfache Suche in Dateien Interner Editor zur Anzeige einer Vorschau der Suchergebnisse Onen der Datei im Editor Kontextmen Find occurrences um Suche in Dateien nach dem Wort unter dem u aktuellen Cursor zu starten.
CodeBlocks V1.1
2.6.2 Verwendung
1. Kongurieren Sie Ihre Einstellungen fr die Suche (see Abbildung 2.7 auf Seite 34) u Nach dem das Plugin installiert wurde gibt es vier Arten die Suche zu starten. a) Eingabe oder Auswahl eines Wortes in der Combo Box ein und Besttigen Sie a Ihre Eingabe mit Return oder drcken Sie den Search Knopf im Thread Search u Panel in der Message Console. b) Eingabe oder Auswahl eines Wortes in der Symbolleiste Search combo box und Besttigen Sie Ihre Eingabe mit Return oder drcken Sie den Search Knopf. a u c) Whlen Sie ein Wort im aktiven Editor und whlen Sie im Kontextmen Find a a u occurrences. d) Selektieren Sie Search/Thread search um den ausgewhlten Begri im aktiven a Editor zu nden. Hinweis: Eintrag 1, 2 und 3 erscheint nur bei entsprechenden Konguration von Thread Search. 2. Erneuntes Bettigen des Search Knopfes bricht die Suche ab. a 3. Durch Anklicken eines Eintrages in der Liste der Suchergebnisse wird auf der linken Seite eine Vorschau angezeigt. 4. Durch Doppelklick eines Eintrages in der Liste der Suchergebnisse wird die zugehrio ge Datei genet und an die gesuchte Stelle gesprungen. o
2.6.3 Einstellungen
Der Knopf Options net den Dialog fr die Konguration des ThreadSearch plugin (see o u Abbildung 2.7 auf Seite 34): 1. Knopf Options in dem Reiter Thread Search der Message Console. 2. Knopf Options der Symbolleiste Thread Search. 3. Men Settings Environment und Eintrag Thread search in der linken Spalte u whlen. a Hinweis: Eintrag 1, 2 und 3 erscheint nur bei entsprechenden Konguration von Thread Search. Sie knnen Filter fr die Suche von Dateien kongurieren. o u Project und Workspace checkboxes schlieen sich gegenseitig aus. Suchpfad kann bearbeitet werden oder uber den Knopf Select konguriert werden. Maske von Dateiendungen, die durch ; getrennt sind. Zum Beispiel: *.cpp;*.c;*.h. Codeblocks 33
CodeBlocks V1.1
2.6.4 Optionen
Whole word Diese Einstellung gibt in den Suchergebnisse nur die Begrie zurck, die u exakt dem Eintrag fr die Suche entsprechen. u Start word Sucht alle Begrie die mit Eintrag der Suche beginnen.. Match case Bercksichtigt Gro- und Kleinschreibung bei der Suche. u Regular expression Regulrer Ausdruck fr eine Suche. a u Hinweis: Um nach regulre Ausdrcken wie n suchen zu knnen, muss in Seta u o tings Editor General Settings der Eintrag Use Advanced RegEx searches aktiviert sein.
CodeBlocks V1.1
voreingestellte Konguration fr das Kontextmen Find occurrences. Standardmig u u a ist die Einstellung Whole word und Match case aktiv. Delete previous results at search begin Bei der Suche mit ThreadSearch und der Einstellung Tree View werden die Suchergebnisse hierarchisch angezeigt, d.h. der erste Knoten ist der Suchbegri selbst darunter werden die Dateien, die den Suchbegri enthalten, gelistet innerhalb der Dateiliste wird die Zeilennummer und der zugehrige Inhalt, wo o der Suchbegri gefunden wurde, angezeigt Bei einer Suche nach mehreren Begrien wird die Liste schnell unbersichtlich, desu halb bietet diese Einstellung die Mglichkeit vorangegangene Suchergebnisse beim o Start einer Suche zu lschen. o Hinweis: In der Anzeige der Suchergebnisse knnen auch einzelne oder alle o Eintrge uber das Kontextmen Delete item bzw. Delete all items a u gelscht werden. o
2.6.6 Layout
Display header in log window Der Name der Dateien wird in den Suchergebnissen angezeigt. Hinweis: Wenn diese Option deaktiviert ist, knnen die Spaltenbreite nicht o mehr verndert werden, belegen jedoch Platz. a Draw lines between columns Anzeigen von Linien zwischen den Spalten im List Mode. Show ThreadSearch toolbar Anzeige der Symbolleiste fr das Thread Search plugin. u Show search widgets in ThreadSearch Messages panel Mit dieser Einstellung werden nur das Fenster fr die Suchergebnisse und der Editor fr die Vorschau angezeigt. Die u u Anzeige aller anderen Elementen fr das Thread Search Plugin wird unterdrckt. u u Show code preview editor Code preview kann entweder in den Thread Search Optionen deaktiviert werden oder durch einen Doppelklick auf die Trennlinie zwischen Code Preview und der Ausgabe der Suchergebnissen versteckt werden. In den Optionen kann die Vorschau wieder aktiviert werden.
Codeblocks
35
CodeBlocks V1.1
Codeblocks
36
CodeBlocks V1.1
Abbildung 2.8: Ansicht des Dateimanagers Fr die Auswahl von Dateien und Verzeichnissen stehen im Kontextmen folgende geu u meinsamen Befehle zur Verfgung. u Duplicate Macht eine Kopie und benennt die Kopie um. Copy To Es net sich ein Dialog in dem Sie das Zielverzeichnis fr das Kopieren auswhlen o u a knnen. o Move To Verschiebt Auswahl an die gewnschte Stelle. u Delete Lscht die ausgewhlten Ordner/Dateien. o a Show Hidden Files Aktiviert bzw. deaktiviert die Anzeige von versteckten Systemdateien. Wenn die Einstellung aktiviert ist, erscheint ein Haken vor dem Eintrag im Kontextmen. u Refresh Aktualisiert die Anzeige im Verzeichnisbaum. Folgende Eintrge sind nur fr die Auswahl ein oder mehrerer Dateien gltig. a u u Open in CB Editor Onet ausgewhlte Datei im CodeBlocks Editor. a Rename Benennt die Datei um. Add to active project Fgt die Datei oder Dateien zum aktiven Projekt hinzu. u Codeblocks 37
Die im File-Explorer ausgewhlten Dateien oder Verzeichnisse sind a uber die Variable mpaths im Shell Extension Plugin verfgbar. u Uber den Menbefehl Settings Environment PowerShell knnen benutzerdeu o nierte Funktionen erstellt werden. In der Eingabemaske des PowerShell wird mit der Schaltche New eine neue Funktion angelegt, die frei benannt werden kann. Im Feld a ShellCommand Executable wird das auszufhrende Programm angegeben, im unteren u Feld knnen dem auszufhrenden Programm zustzliche Parameter ubergeben werden. o u a Durch Auswahl der Funktion im Kontextmen oder PowerShell-Men wird die eingetrau u gene Aktion fr die markierten Dateien oder Verzeichnisse ausgefhrt. Die Ausgabe wird u u dabei auf ein eigenes Shell-Window umgelenkt. Als Beispiel wird fr den Eintrag mit dem Namen SVN ein zugehriger Meneintrag u o u in PowerShell SVN und im Kontextmen des File-Explorers hinzugefgt. Hierbei u u bedeutet $le die Datei, welche im FileExplorer markiert ist, und $mpath die markierten Dateien oder Verzeichnisse.
Add;$interpreter add $mpaths;;;
Dieser sowie jeder weitere Befehl erzeugt ein Untermen, in diesem Fall Extensions u SVN Add . Das Kontextmen wird entsprechend erweitert. Der Aufruf des Konu textmens fhrt das SVN-Kommando add fr die ausgewhlte(n) Datei(en)/Verzeichnis(se) u u u a aus. TortoiseSVN ist ein weit verbreitetes SVN Programm, das im Explorer als context menu integriert ist. Das Programm TortoiseProc.exe von TortoiseSVN kann auch in the Kommandozeile gestartet werden und zeigt einen Dialog an, der zur Eingabe durch den Benutzer dient. Somit knnen die Befehle, die im Kontextmen im Explorer zugnglich o u a sind auch in der Kommandozeile ausgefhrt werden. Dies ermglicht diese Funktionalitt u o a sehr einfach als Shell extension in CodeBlocks einzubauen. Zum Beispiel wird die folgende Eingabe
TortoiseProc.exe /command:diff /path:$file
eine im File Explorer von CodeBlocks ausgewhlte Datei gegen die SVN base Version vera glichen. Siehe hierzu Abbildung 2.9 auf Seite 39 wie dieses Kommando als Shell extension verfgbar wird. u Hinweis: Fr Dateien, die unter SVN stehen, werden im File Explorer overlay u icons angezeigt, wenn diese uber das Kontextmen View SVN u Decorators aktiviert wurden. Beispiel Sie knnen den File-Explorer auch verwendet um Unterschiede zwischen verschiedenen o Dateien oder Verzeichnisse anzeigen zu lassen. Dabei gehen Sie wie folgt vor. Codeblocks 38
CodeBlocks V1.1
Abbildung 2.9: Hinzufgen von Aktionen fr Kontextmen u u u 1. Fgen Sie im Settings Environment PowerShell den Namen ein, der spter u a im Men ShellExtensions bzw. im Kontextmen erscheinen soll. u u 2. Geben Sie den absoluten Pfad des Di-Programms an (z.B. kdi3). Dies wird uber die Variable $interpreter zugegrien. 3. Fgen Sie im unteren Feld den Eintrag: u
Diff;$interpreter $mpaths;;;
In diesem Aufruf wird uber die Variable $mpaths die im File-Explorer selektierten Da teien oder Verzeichnisse zugegrien. Somit knnen Sie einfach ausgewhlte Dateien oder o a Verzeichnisse gegeneineander vergleichen. Als Ubergabeparameter eines Befehl einer PowerShell untersttzt auch den Zugri der in u CodeBlocks verfgbaren Variablen (siehe Abschnitt 3.2 auf Seite 56). u
$interpreter $fname $fext $file $relfile $dir $reldir $path $relpath
Aufzurufendes Programm. Name der Datei ohne Endung. Dateiendung der ausgewhlten Datei. a Dateiname mit Endung. Dateiname ohne Pfadangabe. Ordnername mit Pfadangabe. Ordnername ohne Pfadanabe. Absoluter Pfad. Relativer Pfad einer Datei oder Verzeichnis. 39
Codeblocks
Zeichenkette die durch eine Eingabeauorderung eingegeben wird. Ubergeordnetes Verzeichnis (../)
Hinweis: Die Eintrge fr Shell extension sind auch als Kontextmen im Editor a u u verfgbar. u
Das Fenster Browsed Tabs zum Navigieren in dieser Listen erhalten Sie uber das Men View u Browse Tracker mit dem Eintrag Backward Ed/Forward Ed oder uber das Tas tenkrzel Alt-Left/Alt-Right. Das Browse Tracker Men ist auch uber die Rechte Maustasu u te als Kontextmen zugnglich. Die Marker werden in der Layout-Datei layout le <projectName>.bmar u a gespeichert. Eine huge Arbeitsweise bei der Entwicklung von Software ist, dass man sich durch ein a Satz von Funktion hangelt, die in unterschiedlichen Dateien implementiert sind. Durch das Plugin BrowseTracks knnen Sie somit komfortabel zwischen den Aufrufen in untero schiedlichen Dateien navigieren. Das Plugin erlaubt auch Browse Marker in jeder Datei innerhalb des CodeBlocks Editor zu setzen. Die Cursor Position wird fr jede Datei gespeichert. Das Setzen eines u Markers innerhalb einer Datei ist wahlweise uber das Men View Browse Tracker u Set BrowseMarks oder durch einen Klick mit der linken Maustaste bei gehaltener Ctrl Taste mglich. Der Marker ist durch . . . im linken Seitenrand gekennzeichnet. Uber o das Men View Browse Tracker Prev Mark/Next Mark oder das Tastenkrzel u u Alt-up/Alt-down kann zwischen den Marker innerhalb einer Datei gesprungen werden. Dabei werden die Marker beim Navigieren in der Reihenfolge angesprungen wie diese gesetzt wurden. Falls Sie die Marker innerhalb einer Datei nach Zeilennummern sortiert durchlaufen mchten, whlen Sie einfach das Men View Browse Tracker Sort o a u BrowseMark . Mit dem Clear BrowseMark wird ein Marker in der ausgewhlten Zeile gelscht. Falls a o ein Marker fr ein Zeile gesetzt ist, kann bei gehaltener linker Maustaste (1/4 Sekunde) u und bettigen der Ctrl Taste der Marker fr diese Zeile gelscht werden. Mit dem Aufruf a u o Clear All BrowseMarks oder mit Ctrl-left Klick werden alle Marker innerhalb einer Datei zurckgesetzt. u Die Einstellungen fr das Plugin knnen im Men Settings Editor Browse Tracker u o u verndert werden. a Mark Style Standardmig werden Browse Marks durch . . . im Seitenrand gekennzeicha net. Mit der Einstellung Book Marks werden Browse Marks wie Bookmarks durch Codeblocks 40
CodeBlocks V1.1
einen blauer Pfeil im Rand dargestellt. Mit Hide werden die Darstellung von Browse Marks unterdrckt. u Toggle Browse Mark key Das Setzen oder Lschen von Marker kann entweder durch o eine Klick mit der linken Maustaste oder bei gleichzeitig gehaltener Ctrl-Taste geschehen. Toggle Delay Die Zeitspanne, die eine linke Maustaste gedrckt gehalten sein muss um u in den Browse Marker Modus zu wechseln. Clear All BrowseMarks Lschen aller Marker bei gehaltener Ctrl Taste entweder uber o einen einfachen Klick oder einen Doppelklick mit der linken Maustaste. Die Konguration fr das Plugin wird in den Anwendungsdaten in der Datei default.conf u gepseichert. Bei der Verwenundung einer Personality wird die Konguration aus der Datei <personality>.conf gelesen.
2.10 LibFinder
Wenn Sie Bibliotheken in einer Anwendungen verwenden, muss Ihr Projekt so eingestellt werden, dass es nach diesen Bibliotheken sucht und diese anschlieend benutzen kann. Dieser Vorgang kann zeitaufwndig und nervend sein, da jede Bibliothek unter Umstnden a a durch unterschiedliche Arten von Option eingebunden werden muss. Des weiteren hngen a die Einstellungen vom Host-Betriebssystem ab, was zu Inkompatibilitten im Projekt fr a u die Verwendung unter Unix und Windows fhrt. u LibFinder stellt folgende Kernfunktionalitten zur Verfgung: a u Codeblocks 41
CodeBlocks V1.1
2.10 LibFinder
Suche nach Bibliotheken die bereits auf einem System installiert sind Einbinden von Bibliotheken in Ihr Projekt und somit wird ein Projekt mit nur wenigen Mausklicks plattformunabhngig a
Abbildung 2.10: Liste fr Suchpfade u Wenn LibFinder nach Bibliotheken sucht, verwendet es spezielle Regeln um das Vorhandsein von Bibliotheken zu erkennen. Jeder Satz an Regeln ist im einer xml Datei abgelegt. Derzeit untersttzt LibFinder die Suche von wxWidgets 2.6/2.8, CodeBlocks SDK and u GLFW die Liste wird zuknftig erweitert werden. u Hinweis: Fr nhere Informationen wie eine Untersttzung fr weitere Aru a u u ten von Bibliotheken eingefgt werden kann, lesen Sie bitte die Dau tei src/plugins/contrib/lib finder/lib finder/readme.txt im Quellverzeichnis von CodeBlocks.
Codeblocks
42
CodeBlocks V1.1
2.10 LibFinder
Abbildung 2.11: Suchergebnisse Nach der Suche, zeigt Libnder die Suchergebnisse an (siehe Abbildung 2.11 auf Seite 43). In der Liste whlen Sie dann die Bibliotheken aus, die in der Libnder Datenbank gespeia chert werden sollen. Beachten Sie das jede Bibliothek mehrere gltige Kongurationen u haben kann und die Einstellungen aus vorhergehenden Suchen fr die Erzeugung eines u Projektes dominieren. Mit den nachfolgenden Einstellungen lsst sich kongurieren, wie mit den Ergebnissen a aus vorhergehenden Suchen umgegangen wird. Do not clear previous results Diese Option funktioniert wie ein Update eines existierenden Ergebnis es fgt neue hinzu und aktualisiert bereits bestehende. Die Option u ist nicht ratsam. Second option (Clear previous results for selected libraries) Lscht alle Suchergebniso se fr Bibliotheken, die vor der Suche ausgewhlt wurden. Die Verwendung dieser u a Option wird empfohlen. Clear all previous library settings wenn diese Option ausgewhlt ist, wird die LibFinder a Datenbank aufgerumt bevor neue Suchergebnisse eingefgt werden. Dies ist sinnvoll a u wenn Sie ungltige Eintrge aus der LibFinder Datenbank entfernen wollen. u a Codeblocks 43
CodeBlocks V1.1
2.10 LibFinder
Eine weitere Alternative in diesem Dialog ist die Einstellung Set up Global Variables . Wenn diese Option ausgewhlt ist, versucht LibFinder automatisch die globalen Variablen a zu kongurieren und den Umgang mit den Bibliotheken zu erleichtern. Wenn Sie pkg-cong auf Ihrem System installiert haben (ist meist auf Linux Systemen installiert), wird LibFinder auch die Bibliotheken aus diesem Tool verwenden. Es ist keine weitere Suche erforderlich, da diese beim Start von CodeBlocks automatisch geladen werden.
Abbildung 2.12: Project conguration Die Anzeige von Bibliotheken, die LibFinder bekannt sind, kann geltert werden. Die Checkbox Show as Tree erlaubt das Umschalten zwischen kategorisiert und nicht kategorisierter Ansicht. Wenn Sie Bibliotheken, die nicht in der LibFinder Datenbank verfgbar sind, einfgen wolu u len, whlen Sie den Eintrag Unknown Library . Sie sollte fr die Angabe der Bibliothek a u das ubliche Krzel verwenden (entspricht normalerweise dem globalen Variablennamen) u oder den Name der Bibliothek in pkg-cong. Eine Liste von empfohlen Shortcodes nden Sie auf Global Variables. Die Verwendung dieser Option ist nur dann ratsam, wenn Codeblocks 44
CodeBlocks V1.1
2.11 AutoVersioning
ein Projekt auf unterschiedlichen Systemen erzeugt werden soll, wo die erforderlichen Bibliotheken existieren und durch LibFinder ermittelt werden knnen. Der Zugri auf eine o globale Variable innerhalb von CodeBlocks sieht wie folgt aus:
$(#GLOBAL_VAR_NAME.lib)
Die Auswahl der Option Dont setup automatically wird LibFinder anweisen die Bibliotheken nicht automatisch beim Kompilieren des Projektes einzubinden. In einem solchen Fall kann LibFinder aus einem Build Script ausgefhrt werden. Ein Beispiel fr ein solu u ches Skript wird durch Auswahl des Mens Add manual build script erzeugt und dem u Projekt hinzugefgt. u
2.11 AutoVersioning
Ein Plugin zur Versionierung von Anwendungen, indem die Versions- und Buildnummer ei ner Anwendung jedesmal hochgezhlt wird, wenn eine Anderung stattgefunden hat. Diese a Information wird uber einfach benutzbare Variablendeklarationen in der Datei version.h abgelegt. Des weiteren sind mglich: Ubergaben im SVN Stil, ein Versionsschema Editor, o ein Change Log Generator und ein Log Generator und vieles mehr . . .
2.11.1 Einleitung
Die Idee dieses Plugins entstand bei Entwicklung von Software, die sich im frhen preu alpha Status befand und eine Art von Versionsinformation bentigte. Beschftigt durch o a die Erstellung von Code, blieb keine Zeit um die Versionsnummer zu pegen, deshlab wurde ein Plugin entwickelt, dass diese Arbeit erledigt und nur minimaler Bedienereingri erfordert.
2.11.2 Features
Hier nden Sie eine Liste von Features, die vom Plugin abgedeckt werden. Untersttzung fr C und C++. u u
Codeblocks
45
CodeBlocks V1.1 Generiert und auto inkrementiert Versionsvariablen. Software status editor.
2.11 AutoVersioning
Integrierter Schemeneditor fr die Konguration wie automatische Hochzhlen der u a version values geschehen soll. Datum deklariert als Monat, Datum und Jahr. Ubuntu style version. Svn revision check. Change log generator. Funktioniert unter Windows und Linux.
2.11.3 Handhabung
Whlen Sie einfach das Men Project Autoversioning . Das Pop Up Fenster wie auf a u ?? auf Seite ?? erscheint.
Abbildung 2.13: Congure project for Autoversioning Wenn Sie den Dialog mit yes besttigen, dann wird der Kongurationsdialog von Autoa versioning angezeigt. Nachdem Sie Ihr Projekt fr Autoversioning konguriert haben, werden die Einstellungen u aus dem Eingabedialog im Projekt gespeichert und eine Datei version.h wird angelegt. Ab diesem Zeitpunkt wird bei jedem Aufruf des Mens Project Autoversioning der u Kongurationsdialog aufgerufen, um die Einstellung fr Projektversion vorzunehmen, es u sei denn Sie speichern die Anderungen des Plugins in Projektdatei.
CodeBlocks V1.1
2.11 AutoVersioning
Build Number Gleichbedeutend mit Release und wird jedesmal wenn die Revison Number steigt um eins hochgezhlt. a Revision Zhlt die Revision zufallsartig hoch, wenn das Projekt gendert oder kompiliert a a wurde.
Abbildung 2.14: Set Version Values 2.11.4.2 Status Einige Felder sind auf vordeniert Werte voreingestellt (siehe Abbildung 2.15 auf Seite 48). Software Status Ein typisches Beispiel wre v1.0 Alpha a Abbreviation Gleichbedeutend mit Software Status, aber in der Form: v1.0a 2.11.4.3 Scheme Hier stellen Sie ein, wie das Plugin die version values hochzhlt (siehe Abbildung 2.16 auf a Seite 48). Minor maximum Die obere Schranke fr den Wert Minor. Wenn diese erreicht ist, wird u Major hochgezhlt und beim nchsten Kompilevorgang des Projektes wird Minor a a auf Null zurckgesetzt. u Build Number maximum Wenn der Wert erreicht wurde, wird beim nchsten Kompilea vorgang der Wert auf Null zurckgesetzt. Die Einstellung 0 setzt das Maximum auf u unendlich
Codeblocks
47
CodeBlocks V1.1
2.11 AutoVersioning
Codeblocks
48
CodeBlocks V1.1
2.11 AutoVersioning
Revision maximum Gleichbedeutend mit Maximum fr Build Number maximum. Die u Einstellung 0 setzt das Maximum auf unendlich Revision random maximum Die Revisions Nummer wird durch Zufallszahlen hochgezhlt. a Eine Einstellung mit 1, wird die Revision um eins erhhen. o Build times before incrementing Minor Nach Anderungen im Code und Kompilierung wird die Build History inkrementiert und wenn dieser Wert erreicht wird, dann wir der Minor Wert auch inkrementiert. 2.11.4.4 Einstellungen Hier knnen Sie einige Einstellungen fr Auto Versioning vornehmen (siehe Abbildung 2.17 o u auf Seite 49).
Abbildung 2.17: Settings von Autoversioning Autoincrement Major and Minor Lassen Sie das Plugin nach diesem Schema den Wert inkrementieren. Wenn es nicht ausgewhlt wurde, dann wird nur die Build Number a und die Revision hochgezhlt. a Create date declarations Erzeugt in der Datei version.h Eintrge fr Datum und Ubuna u tu style version. Do Auto Increment Weist das Plugin an bei jeder Anderung noch vor dem Kompilevorgang zu inkrementieren. Header language Einstellung der Sprache fr Ausgabe in version.h u Codeblocks 49
CodeBlocks V1.1
2.11 AutoVersioning
Ask to increment Wenn Do Auto Increment aktiv ist, wird vor dem Kompilevorgang bei Anderungen nachgefragt, ob hochgezhlt werden soll. a svn enabled Sucht nach der SVN Revision und Datum im aktuellen Verzeichnis und erzeugt die zugehrigen Eintrge in version.h o a 2.11.4.5 Changes Log Durch diese Einstellung wird die Eingabe fr jegliche Anderung an einem Projekt in die u Datei ChangesLog.txt generiert (siehe Abbildung 2.18 auf Seite 50).
Abbildung 2.18: Changelog von Autoversioning Show changes editor when incrementing version Ruft den Changes log editor auf, wenn die Version inkrementiert wird. Title Format Format fr Title mit einer Liste von vordenierten Werten. u
Codeblocks
50
2.11 AutoVersioning
Die erzeugte Headerdatei knnte beispielsweise im C++ Mode wie folgt aussehen: o
#ifndef VERSION_H #define VERSION_H namespace AutoVersion{ //Date static static static static Version Types const char DATE[] = "15"; const char MONTH[] = "09"; const char YEAR[] = "2007"; const double UBUNTU_VERSION_STYLE = 7.09;
//Software Status static const char STATUS[] = "Pre-alpha"; static const char STATUS_SHORT[] = "pa"; //Standard Version Type static const long MAJOR = 0; static const long MINOR = 10; static const long BUILD = 1086; static const long REVISION = 6349; //Miscellaneous Version Types static const long BUILDS_COUNT = 1984; #define RC_FILEVERSION 0,10,1086,6349 #define RC_FILEVERSION_STRING "0, 10, 1086, 6349\0" static const char FULLVERSION_STRING[] = "0.10.1086.6349"; } #endif //VERSION_h
Bei der Einstellung der Sprache C ergibt sich folgende Ausgabe ohne Namespaces:
#ifndef VERSION_H #define VERSION_H //Date static static static static Version Types const char DATE[] = "15"; const char MONTH[] = "09"; const char YEAR[] = "2007"; const double UBUNTU_VERSION_STYLE = 7.09;
//Software Status static const char STATUS[] = "Pre-alpha"; static const char STATUS_SHORT[] = "pa"; //Standard Version Type static const long MAJOR = 0; static const long MINOR = 10; static const long BUILD = 1086; static const long REVISION = 6349; //Miscellaneous Version Types static const long BUILDS_COUNT = 1984;
Codeblocks
51
CodeBlocks V1.1
2.11 AutoVersioning
#define RC_FILEVERSION 0,10,1086,6349 #define RC_FILEVERSION_STRING "0, 10, 1086, 6349\0" static const char FULLVERSION_STRING[] = "0.10.1086.6349"; #endif //VERSION_h
2.11.6.1 Buttons Summary Add Fgt eine Zeile in der Liste hinzu u Edit Editieren einer ausgwhlte Zelle a Delete Lscht die ausgewhlte Zeile aus der Liste o a Save Speichert die aktuellen Daten temporr in der Datei (changes.tmp). Diese Infora mation wird spter fr die Ausgabe in Changes Log verwendet a u Codeblocks 52
CodeBlocks V1.1 Write Speichert die Eingabe in der Changes Log Datei Cancel Beendet den Dialog
Hier ein Beispiel fr eine Datei ChangesLog.txt, die durch Auto Versioning erzeugt wuru de.
03 September 2007 released version 0.7.34 of AutoVersioning-Linux Change log: -Fixed: pointer declaration -Bug: blah blah 02 September 2007 released version 0.7.32 of AutoVersioning-Linux Change log: -Documented some areas of the code -Reorganized the code for readability 01 September 2007 released version 0.7.30 of AutoVersioning-Linux Change log: -Edited the change log window -If the change log windows is leave blank no changes.txt is modified
Abbildung 2.20: Konguration fr Code Statistik u Anhand der Angaben in der Kongurationsmaske ermittelt dieses einfache Plugin die Anteile von Code, Kommentaren und Leerzeilen fr ein Projekt. Die Auswertung wird u uber das Men Plugins Code statistics durchgefhrt. u u
CodeBlocks V1.1
Durch diese Datenbanksuche nden Sie schnell Quellcode der aus anderen weltweiten Projekten von Universitten, Consortiums und Organisationen wie Apache, Mozilla, Novell a Forge, SourceForge und vielen mehr stammt und wiederverwendet werden kann, ohne dass jedes Mal das Rad neu erfunden werden muss. Bitte beachten Sie die jeweilige Lizenz des Quellcodes.
Abbildung 2.21: Konguration von Symbol Table Mit der Schaltche Search wird die Suche gestartet und die Ergebnisse des Programms a NM werden in einem eigenen Fenster SymTabs Result angezeigt. Der Name des Objekts bzw. Bibliothek, die das Symbol enthalten ist unter dem Titel NMs Output gelistet.
Codeblocks
54
3 Variable Expansion
CodeBlocks dierentiates between several types of variables. These types serve the purpose of conguring the environment for creating a program, and at the same of improving the maintainability and portability. Access to the CodeBlocks variables is achieved via $<name>. Envrionment Variable are set during the startup of CodeBlocks. They can modify system environment variables such as PATH. This can be useful in cases where a dened environment is necessary for the creation of projects. The settings for environment variables in CodeBlocks are made at Settings Environment Environment Variables . Builtin Variables are predened in CodeBlocks, and can be accessed via their names (see Abschnitt 3.2 auf Seite 56 for details). Command Macros This type of variables is used for controlling the build process. For further information please refer to Abschnitt 3.4 auf Seite 60. Custom Variables are user-dened variables which can be specied in the build options of a project. Here you can, for example dene your derivative as a variable MCU and assign a corresponding value to it. Then set the compiler option -mcpu=$(MCU), and CodeBlocks will automatically replace the content. By this method, the settings for a project can be further parametrised. Global Variables are mainly used for creating CodeBlocks from the sources or developments of wxWidgets applications. These variables have a very special meaning. In contrast to all others if you setup such a variables and share your project le with others that have *not* setup this GV CodeBlocks will ask the user to setup the variable. This is a very easy way to ensure the other developer knows what to setup easily. CodeBlocks will ask for all paths usually necessary.
3.1 Syntax
CodeBlocks treats the following functionally identical character sequences inside pre-build, post-build, or build steps as variables: $VARIABLE $(VARIABLE) ${VARIABLE} %VARIABLE% Variable names must consist of alphanumeric characters and are not case-sensitive. Variables starting with a single hash sign (#) are interpreted as global user variables (see
CodeBlocks V1.1
Abschnitt 3.7 auf Seite 60 for details). The names listed below are interpreted as built-in types. Variables which are neither global user variables nor built-in types, will be replaced with a value provided in the project le, or with an environment variable if the latter should fail. Hinweis: Per-target denitions have precedence over per-project denitions.
The name of the workspace that is displayed in tab Projects of the Management panel.
$(WORKSPACE_DIR), $(WORKSPACE_DIRECTORY), $(WORKSPACEDIR), $(WORKSPACEDIRECTORY)
the directory containing the currently active le (relative to the common top level path).
$(ACTIVE_EDITOR_STEM)
Codeblocks
56
CodeBlocks V1.1
$(ACTIVE_EDITOR_EXT)
The lename of the makele. The path to the currently running instance of CodeBlocks.
The plugins directory of the currently running instance of CodeBlocks. The compiler installation directory so-called master path.
$(TARGET_COMPILER_DIR)
The output les base name (no path, no extension) of a specic target.
$(TARGET_OUTPUT_DIR)
The output les base name (no path, no extension) of the current target.
$(TARGET_CC), $(TARGET_CPP), $(TARGET_LD), $(TARGET_LIB)
The build tool executable (compiler, linker, etc) of the current target.
The system language in plain language. The character encoding in plain language.
Codeblocks
57
CodeBlocks V1.1
Current date in the form YYYYMMDD (for example 20051228) Current date in the form YYYY-MM-DD (for example 2005-12-28) Timestamp in the form YYYY-MM-DD-hh.mm (for example 2005-1228-07.15) ] Timestamp in the form YYYY-MM-DD-hh.mm.ss (for example 200512-28-07.15.45) Plain language day of the week (for example Wednesday) These are identical to the preceding types, but are expressed relative to UTC.
$(NOW_L)
$(WEEKDAY)
$(DAYCOUNT)
The number of the days passed since an arbitrarily chosen day zero (January 1, 2009). Useful as last component of a version/build number.
This variable tosses a virtual coin (once per invocation) and returns 0 or 1. A 16-bit positive random number (0-65535)
$(RANDOM)
Copy command for les. Remove command for les. Move command for les. Make directory command. Remove directory command.
Conditional evaluation will resolve to its true clause if condition is a non-empty character sequence other than 0 or false condition is a non-empty variable that does not resolve to 0 or false condition is a variable that evaluates to true (implicit by previous condition) Conditional evaluation will resolve to its false clause if Codeblocks 58
CodeBlocks V1.1 condition is empty condition is 0 or false condition is a variable that is empty or evaluates to 0 or false Hinweis:
Please do note that neither the variable syntax variants %if (...) nor
$( if )(...) are supported for this construct.
Example For example if you are using several platforms and you want to set dierent parameters depending on the operating system. In the following code the script commands of [[ ]] are evaluated and the <command> will be executed. This could be useful in a post-built step.
[[ if (PLATFORM == PLATFORM_MSW) { print (_T("cmd /c")); } else { print (_T("sh ")); }
The expression in backticks returns a list of all executables *.elf in any subdirectories. The result of this expression can be used directly by objdump. Finally the output is piped to a le named name.dis. Thus, processes can be automatted in a simple way without having to program any loops. Example using Script The script text is replaced by any output generated by your script, or discarded in case of a syntax error. Since conditional evaluation runs prior to expanding scripts, conditional evaluation can be used for preprocessor functionalities. Built-in variables (and user variables) are expanded after scripts, so it is possible to reference variables in the output of a script.
[[ print(GetProjectManager().GetActiveProject().GetTitle()); ]]
inserts the title of the active project into the command line. Codeblocks 59
CodeBlocks V1.1
Access to name of the compiler executable. Access to name of the linker executable. Compiler ags Linker ags Compiler include paths Linker include paths Linker libraries Source le (full name) Source le directory without le name and le name extension. Source le name without path info and le name extension. Directory of executable without le name and le name extension. File name of executable without path and le name extension. File name extension of executable without path and le name. Object le Executable output le Object Output Directory
$objects_output_dir
CodeBlocks V1.1
The concept of global compiler variables is a unique new solution for CodeBlocks which addresses this problem. Global compiler variables allow you to set up a project once, with any number of developers using any number of dierent le system layouts being able to compile and develop this project. No local layout information ever needs to be changed more than once.
3.10 Constraints
Both set and global compiler variable names may not be empty, they must not contain white space, must start with a letter and must consist of alphanumeric characters. Cyrillic or Chinese letters are not alphanumeric characters. If CodeBlocks is given invalid character sequences as names, it might replace them without asking. Every variable requires its base to be dened. Everything else is optional, but the base is absolutely mandatory. If you dont dene a the base of a variable, it will not be saved (no matter what other elds you have dened). You may not dene a custom member that has the same name as a built-in member. Currently, the custom member will overwrite the built-in member, but in general, the behaviour for this case is undened. Variable and member values may contain arbitrary character sequences, subject to the following three constraints: You may not dene a variable by a value that references the same variable or any of its members Codeblocks 61
CodeBlocks V1.1
Abbildung 3.1: Global Variable Environment You may not dene a member by a value that references the same member You may not dene a member or variable by a value that references the same variable or member through a cyclic dependency. CodeBlocks will detect the most obvious cases of recursive denitions (which may happen by accident), but it will not perform an in-depth analysis of every possible abuse. If you enter crap, then crap is what you will get; you are warned now. Examples Dening wx.include as $(#wx)/include is redundant, but perfectly legal Dening wx.include as $(#wx.include) is illegal and will be detected by CodeBlocks Dening wx.include as $(#cb.lib) which again is dened as $(#wx.include) will create an innite loop
Codeblocks
62
CodeBlocks V1.1
Abbildung 3.2: Global Variables menu. Example The above image shows both per-project and global variables. WX_SUFFIX is dened in the project, but WX is a global user variable.
Codeblocks
63
CodeBlocks V1.1
Codeblocks
64
URL catalog
[ 7Z] 7z zip homepage. http://www.7-zip.org [ BERLIOS] Codeblocks at berlios. http://developer.berlios.de/projects/codeblocks/ [ FORUM] Codeblocks forum. http://forums.codeblocks.org/ [ WIKI] Codeblocks wiki. http://wiki.codeblocks.org/index.php?title=Main_Page/ [ CODEBLOCKS] Codeblocks homepage. http://www.codeblocks.org/ [ GCC] GCC home page. http://gcc.gnu.org/ [ HIGHTEC] HighTec homepage. http://www.hightec-rt.com/ [ Koders] Koders homepage. http://www.koders.com/ [ TriCore] TriCore homepage. http://www.infineon.com/tricore/ [ TortoiseSVN] TriCore homepage. http://tortoisesvn.net/ [ Subversion] TriCore homepage. http://subversion.tigris.org/ [ Wxwidgets] WxWidgets homepage. http://www.wxwidgets.org/ [ Wxcode] WxCode homepage. http://wxcode.sourceforge.net/ [ Scripts] Scripting commands. http://wiki.codeblocks.org/index.php?title=Scripting_commands/