Menu

[r3923]: / trunk / Src / Help / HTML / dlg_configcompilers.htm  Maximize  Restore  History

Download this file

293 lines (291 with data), 11.4 kB

  1
  2
  3
  4
  5
  6
  7
  8
  9
 10
 11
 12
 13
 14
 15
 16
 17
 18
 19
 20
 21
 22
 23
 24
 25
 26
 27
 28
 29
 30
 31
 32
 33
 34
 35
 36
 37
 38
 39
 40
 41
 42
 43
 44
 45
 46
 47
 48
 49
 50
 51
 52
 53
 54
 55
 56
 57
 58
 59
 60
 61
 62
 63
 64
 65
 66
 67
 68
 69
 70
 71
 72
 73
 74
 75
 76
 77
 78
 79
 80
 81
 82
 83
 84
 85
 86
 87
 88
 89
 90
 91
 92
 93
 94
 95
 96
 97
 98
 99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 3.2 Final//EN">
<!--
* This Source Code Form is subject to the terms of the Mozilla Public License,
* v. 2.0. If a copy of the MPL was not distributed with this file, You can
* obtain one at http://mozilla.org/MPL/2.0/
*
* Copyright (C) 2005-2013, Peter Johnson (www.delphidabbler.com).
*
* $Rev$
* $Date$
*
* Help topic for Configure Compilers dialogue box.
-->
<html>
<head>
<meta
http-equiv="Content-Type"
content="text-html; charset=Windows-1252">
<title>
Configure Compilers Dialogue Box
</title>
<link
rel="stylesheet"
href="../css/codesnip.css"
type="text/css">
</head>
<body>
<object
type="application/x-oleobject"
classid="clsid:1e2a7bd0-dab9-11d0-b93a-00c04fc99f9e">
<param
name="ALink Name"
value="CompilersDlg">
</object>
<h1>
<a name="dlg_configcompilers"></a>Configure Compilers Dialogue Box
</h1>
<p>
This dialogue box is used to let <em>CodeSnip</em> know about the Pascal
Compilers that are installed on the system. It is displayed using the
<em>Tools | Configure Compilers</em> menu option. <em>CodeSnip</em> uses
these compilers when <a href="about_compiler_checks.htm">test
compiling</a> routines.
</p>
<p>
Supported compilers are listed on the left hand side of the dialogue. If a
compiler is known to <em>CodeSnip</em> its name appears in bold. Unknown
compilers (or compilers that are not installed on the local system)
appear in plain text.
</p>
<p>
Any changes you make do not affect other users.
</p>
<p>
Selecting a compiler on the left displays information about it on the
right hand side of the dialogue. Here you enter or edit the required
information on three tabs, as follows.
</p>
<h2>
Compiler Tab
</h2>
<p>
Enter the the full path to the compiler's executable file in the <em>Enter
compiler executable file name</em> edit box. This must be file name of
the command line version of the compiler - for example Delphi's DCC32.exe.
If you prefer you can select the file name from a standard file dialogue
by clicking the ellipsis button to the right of the edit box. The chosen
file name is entered in the edit box. As soon as the cursor leaves the
edit box the file name is checked for validity &ndash; it must exist and
be an executable file. If it valid it is used and compiler name will be
emboldened.
</p>
<p>
Pressing the <em>Clear</em> button removes the compiler by deleting the
path to its executable file. The <em>Enter compiler executable file
name</em> edit box is cleared.
</p>
<p>
Finally, you can choose whether the compiler is included in the table of
compile results displayed in the <a href="detail_pane.htm">Details
Pane</a>. This is done using the <em>Display results for this compiler in
details pane</em> check box. Tick the box to display the compiler's
results or clear it to hide them.
</p>
<p>
<strong
class="warning"
>Important Note:</strong> The facility to switch off the display of
results for selected compilers was designed to limit the number of
compilers whose results are displayed to avoid cluttering the
<a href="detail_pane.htm">Details Pane</a> with unnecessary information.
The feature should not be used to switch off the display of all compilers:
doing that will cause a warning message to be displayed in place of the
compiler results table. To switch off compiler results completely you
should use the <a href="dlg_prefs_snippetlayout.htm">Snippet Layout</a>
tab of the <a href="dlg_preferences.htm">Preferences</a> dialogue box to
remove the <em>Compiler Results Table</em> component from the different
kinds of snippet pages.
</p>
<h2>
Switches
</h2>
<p>
<em>CodeSnip</em> passes certain switches to the command line of each
supported compiler. You can edit these switches if you wish the compilers
to perform differently. You can add, delete or edit switches as follows:
</p>
<ul>
<li>
<em>Add a switch</em>. Enter its name in the edit box and click
<em>Add</em>.
</li>
<li>
<em>Delete a switch</em>. Select the switch in the list box the click
the <em>Delete</em> button.
</li>
<li>
<em>Edit a switch</em>. Select the switch in the list box to copy it to
the edit box. Change the switch and click <em>Replace</em>.
</li>
<li>
<em>Restore default switches</em>. Click the <em>Defaults</em> button.
This can be useful if you have made some changes to switches and <em>
CodeSnip</em> ceases to function properly.
</li>
</ul>
<p>
For an explanation of the purpose of the switches please see your
compiler's documentation.
</p>
<p>
<strong>Notes:</strong>
</p>
<ol>
<li>
There is no need to use this tab to provide switches to set the compiler
search path &ndash; that is very cumbersome. Instead you can use the
<em>Search Paths</em> tab to define your search paths and to generate
the correct switches automatically.
</li>
<li>
Similarly, when you have selected the Delphi XE2 or later compiler,
there is no need to set up the <code>-NS</code> switch to specify the
namespaces to search for various units. The <em>Namespaces</em> tab can
be used to make this task simpler and to generate the correct
<code>-NS</code> switch.
</li>
</ol>
<p>
<strong
class="warning"
>Warning:</strong> You should not remove any switches that cause the
compilers to generate warnings and error messages since <em>CodeSnip</em>
will not detect compilation errors correctly without these switches. You
are strongly recommended not to pass any switches that alter the
compiler's output otherwise <em>CodeSnip</em> may fail to operate
correctly.
</p>
<h2>
Namespaces
</h2>
<p class="bordered">
<strong>Note:</strong> This tab appears only if the selected compiler is
Delphi XE2 or later.
</p>
<p>
Delphi XE2 or later qualify units from the RTL and VCL are prefixed with
the name of the unit's namespace. Much of the code managed by
<em>CodeSnip</em> uses unqualified unit names for reasons of backward
compatibility. In order for the unqualifed units to be found on Delphi
XE2 and later the compiler has to be given a list of namespaces to search
for the units.
</p>
<p>
This tab enables you to configure such a namespace, as follows:
</p>
<ul>
<li>
<em>Add a namespace</em>. Enter its name in the edit box and click
<em>Add</em>.
</li>
<li>
<em>Delete a namespace</em>. Select the namespaces in the list box the
click the <em>Delete</em> button.
</li>
<li>
<em>Edit a namespace</em>. Select the namespace in the list box to copy
it to the edit box. Change the namespace name and click
<em>Replace</em>.
</li>
<li>
<em>Restore default namespaces</em>. Click the <em>Defaults</em> button.
This can be useful if you have made some changes to namespaces and
<em>CodeSnip</em> fails to compile snippets correctly. The default
namespaces have been chosen because they contain the most commonly used
units.
</li>
</ul>
<p>
For an list of RTL and VCL units, and the namespaces to which thet belong,
see your compiler's documentation.
</p>
<h2>
Search Paths
</h2>
<p>
If you have your own or third party units you want your user-defined
routines to reference you need to tell the compilers where to find them.
This tab lets you do just that. Because you often use different versions
of the same unit for different compilers, you must set up each compiler's
search path separately.
</p>
<p>
The <em>Existing Paths</em> list displays any current search paths. You
edit the search paths as follows:
</p>
<ul>
<li>
<em>Add a path</em>. Enter the required directory in the <em>Add or edit
path</em> edit box then click <em>Add</em>. You can browse for the
directory using a standard <em>Browse For Folders</em> dialogue box by
clicking the ellipsis button to the right of the edit control.
</li>
<li>
<em>Edit an existing path</em>. Select the directory in the list box.
This copies the directory name to the edit control. Modify the name then
click <em>Replace</em>.
</li>
<li>
<em>Delete a path</em>. Select the directory in the list box and press
<em>Delete</em>.
</li>
<li>
<em>Change the order of the search paths</em>. Select a directory in the
list box then move it up and down the list using the buttons that
display the up and down arrows. <span class="smallcaps">Ctrl+Up</span>
and <span class="smallcaps">Ctrl+Down</span> have the same effect.
</li>
</ul>
<h2>
Output Log Tab
</h2>
<p>
<em>CodeSnip</em> logs and examines the output of the compiler to
determine if the compilation was clean or contained warnings. It also
examines the output for error messages when the compilation fails. A
summary of the logged output can be displayed by the user when warnings
or errors occur. Instead of displaying the whole log the program filters
out the required messages. It does this by looking for some common text
that preceeds the messages in the log. These prefixes are listed in the
<em>Log Prefixes</em> editor.
</p>
<p>
If you are using an English language version of a compiler the default
values will be correct. For all Delphis and Free Pascal the default
values are:
</p>
<ul>
<li>
For fatal errors: &quot;Fatal: &quot;
</li>
<li>
For general errors: &quot;Error: &quot;
</li>
<li>
For warnings: &quot;Warning: &quot;
</li>
</ul>
<p>
For languages other than English you need to compile some code that
generates warnings, errors and fatal errors then check what text preceeds
each kind of message. This text should be entered in the <em>Log
Prefixes</em> editor. Failure to do this will mean that CodeSnip
won't detect warnings and won't report errors correctly.
</p>
<h2>
Auto Detecting Compilers
</h2>
<p>
<em>CodeSnip</em> can automatically detect the presence of Win 32 Delphi
compilers from versions 2 to XE5. Click the <em>Detect Delphi
Compilers</em> button to do this. Any supported installed version of
Delphi will be recorded. This can save considerable time and avoid
errors.
</p>
<p>
Free Pascal cannot be detected automatically and must be configured
manually.
</p>
</body>
</html>
Want the latest updates on software, tech news, and AI?
Get latest updates about software, tech news, and AI from SourceForge directly in your inbox once a month.