Menu

[r4335]: / branches / parsnip / Src / Compilers.UGlobals.pas  Maximize  Restore  History

Download this file

358 lines (291 with data), 14.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
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
{
* 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$
*
* Declares various types that describe the compiler and compilation results and
* defines interfaces to compiler objects.
}
unit Compilers.UGlobals;
interface
uses
// Delphi
Generics.Collections, Classes, Graphics;
type
/// <summary>Enumeration that identifies all compilers supported by the
/// program.</summary>
/// <remarks>
/// <para>- ciD2 - Delphi 2 compiler.</para>
/// <para>- ciD3 - Delphi 3 compiler.</para>
/// <para>- ciD4 - Delphi 4 compiler.</para>
/// <para>- ciD5 - Delphi 5 compiler.</para>
/// <para>- ciD6 - Delphi 6 compiler.</para>
/// <para>- ciD7 - Delphi 7 compiler.</para>
/// <para>- ciD2005 - Delphi 2005 for Win 32 compiler.</para>
/// <para>- ciD2006 - Delphi 2006 for Win 32 compiler.</para>
/// <para>- ciD2007 - Delphi 2007 for Win 32 compiler.</para>
/// <para>- ciD2009 - Delphi 2009 for Win 32 compiler.</para>
/// <para>- ciD2010 - Delphi 2010 compiler (Win 32 only).</para>
/// <para>- ciDXE - Delphi XE Win 32 compiler.</para>
/// <para>- ciDXE2 - Delphi XE2 Win 32 compiler.</para>
/// <para>- ciDXE3 - Delphi XE3 Win 32 compiler.</para>
/// <para>- ciDXE4 - Delphi XE4 Win 32 compiler.</para>
/// <para>- ciDXE5 - Delphi XE5 Win 32 compiler.</para>
/// <para>- ciFPC - Free Pascal Compiler.</para>
/// <para>IMPORTANT NOTE: Any new compiler IDs must be added to the END of
/// the enumeration. Some code depends on the ordering of this enueration
/// and will fail if it changes.</para>
/// </remarks>
TCompilerID = (
ciD2, ciD3, ciD4, ciD5, ciD6, ciD7, ciD2005, ciD2006, ciD2007, ciD2009,
ciD2010, ciDXE, ciDXE2, ciDXE3, ciDXE4, ciDXE5, ciFPC
// NOTE: enter any new compiler IDs here
);
/// <summary>Set of compiler ID identifiers from TCompilerID enumeration.
/// </summary>
TCompilerIDs = set of TCompilerID;
const
/// <summary>Set of classic Borland / Inprise Delphi compilers.</summary>
cClassicDelphiCompilers = [ciD2, ciD3, ciD4, ciD5, ciD6, ciD7];
const
/// <summary>Set of Borland / CodeGear / Embarcadero BDS based Delphi
/// compilers.</summary>
cBDSCompilers = [
ciD2005, ciD2006, ciD2007, ciD2009, ciD2010, ciDXE, ciDXE2, ciDXE3, ciDXE4,
ciDXE5
];
const
/// <summary>Set of Free Pascal compilers.</summary>
/// <remarks>At present there is only the one compiler: no distinction is
/// made between different versions.</remarks>
cFreePascalCompilers = [ciFPC];
type
/// <summary>Enumeration of possible results of a compilation.</summary>
TCompileResult = (
crSuccess, // successful compilation without warnings
crWarning, // successful compilation with warnings
crError, // compilation failed
crQuery // compilation result not known
);
type
/// <summary>Defines an array of TCompileResult values with an element for
/// each supported compiler.</summary>
TCompileResults = array[TCompilerID] of TCompileResult;
type
/// <summary>Enumeration of different warning and error prefixes that can be
/// recognised in a compiler log file.</summary>
/// <remarks>These values are used to identify the prefix text used by a
/// compiler.</remarks>
TCompLogPrefixID = (
cpFatal, // identifies fatal error messages in log file
cpError, // identifies error messages in log file
cpWarning // identifies warnings in log file
);
type
/// <summary>Defines an array used to store prefix text of warning and error
/// messages in compiler log files.</summary>
/// <remarks>Prefixes may be different for each compiler and may change with
/// the compiler's output language.</remarks>
TCompLogPrefixes = array[TCompLogPrefixID] of string;
type
/// <summary>Enumeration of various filter types that can be applied to
/// compiler output logs.</summary>
TCompLogFilter = (
cfAll, // no filtering: use all of log
cfWarnings, // filter out anything that is not a warning message
cfErrors // filter out anything that is not an error message
);
type
/// <summary>Interface to list of directories to be searched by a compiler
/// when looking for files.</summary>
ISearchDirs = interface(IInterface)
['{77CAFAC1-9B0F-4244-9FFF-A9FB4EBDEE8B}']
/// <summary>Creates and returns enumerator for directories list.</summary>
function GetEnumerator: TEnumerator<string>;
/// <summary>Adds a new search directory to list.</summary>
procedure Add(const DirName: string);
/// <summary>Clears list.</summary>
procedure Clear;
/// <summary>Checks if list is empty.</summary>
function IsEmpty: Boolean;
/// <summary>Returns an array containing the names of all directories in
/// the list.</summary>
function ToStrings: TArray<string>;
end;
type
/// <summary>Interface that must be supported by any object that represents a
/// compiler. Exposes methods used to get information about the compiler, to
/// execute the compiler and to process the compiler's log file.</summary>
ICompiler = interface(IInterface)
['{8D473D8A-3341-401C-B054-17E9334DF6A6}']
/// <summary>Returns the human readable name of the compiler.</summary>
function GetName: string;
/// <summary>Returns the compiler's unique ID.</summary>
function GetID: TCompilerID;
/// <summary>Returns a non-localisable string that uniquely identifies the
/// compiler.</summary>
function GetIDString: string;
/// <summary>Checks whether the compiler is both installed on this computer
/// and made available to CodeSnip.</summary>
function IsAvailable: Boolean;
/// <summary>Returns the full path of the compiler's executable file.
/// </summary>
/// <remarks>Returns the empty string if the compiler is not known to
/// CodeSnip.</remarks>
function GetExecFile: string;
/// <summary>Records the the full path of the compiler's executable file.
/// </summary>
/// <remarks>Passing the empty string to this method disassociates the
/// compiler from CodeSnip.</remarks>
procedure SetExecFile(const Value: string);
/// <summary>Returns a comma separated list of the default command line
/// switches for use with the compiler.</summary>
/// <remarks>The default switches are used if the user has not provided any
/// switches.</remarks>
function GetDefaultSwitches: string;
/// <summary>Returns a comma separated list of any user defined switches
/// for use with the compiler.</summary>
function GetSwitches: string;
/// <summary>Records the given comma delimited list of user defined
/// switches to be used with the compiler.</summary>
procedure SetSwitches(const Switches: string);
/// <summary>Checks if the compiler has RTL unit names that are prefixed by
/// its namespace.</summary>
function RequiresRTLNamespaces: Boolean;
/// <summary>Returns a space separated list of the compiler's default RTL
/// unit namespaces.</summary>
function GetDefaultRTLNamespaces: string;
/// <summary>Returns a space separated list of user-defined RTL unit
/// namespaces to be searched by the compiler.</summary>
function GetRTLNamespaces: string;
/// <summary>Records a list of user defined RTL unit namespaces to be
/// searched by the compiler.</summary>
/// <remarks>Namespaces is expected to be a space separated list of valid
/// Pascal identfiers.</remarks>
procedure SetRTLNamespaces(const Namespaces: string);
/// <summary>Returns a copy of the list of search directories used by the
/// compiler.</summary>
function GetSearchDirs: ISearchDirs;
/// <summary>Records a copy of the given list of search directories to be
/// used by the compiler.</summary>
procedure SetSearchDirs(Dirs: ISearchDirs);
/// <summary>Returns the prefixes used in interpreting error, fatal error
/// and warning conditions in compiler log files.</summary>
function GetLogFilePrefixes: TCompLogPrefixes;
/// <summary>Records the given prefixes to be used in interpreting error,
/// fatal error and warning conditions in compiler log files.</summary>
procedure SetLogFilePrefixes(const Prefixes: TCompLogPrefixes);
/// <summary>Returns a flag indicating if the compiler is displayable.
/// </summary>
/// <remarks>A 'displayable' compiler has its compile results displayed in
/// the UI etc.</remarks>
function GetDisplayable: Boolean;
/// <summary>Sets the flag that determines if the compiler is displayable
/// to the given value.</summary>
/// <remarks>A 'displayable' compiler has its compile results displayed in
/// the UI etc.</remarks>
procedure SetDisplayable(const Flag: Boolean);
/// <summary>Compiles a project and returns the result of compilation.
/// </summary>
/// <param name="Path">string [in] The full path of the directory
/// containing the project file.</param>
/// <param name="Project">string [in] Name of project source file.</param>
/// <returns>TCompileResult. Result of compilation (success, warning or
/// error).</returns>
/// <exception>An exception is raised if the compiler can't be executed.
/// </exception>
/// <remarks>The result of the compilation and the compiler output log are
/// stored: see the Log and GetLastCompileResult methods.</remarks>
function Compile(const Path, Project: string): TCompileResult;
/// <summary>Deletes intermediate files created during a compilation of a.
/// project.</summary>
/// <param name="Path">string [in] The full path of the directory
/// containing the project file.</param>
/// <param name="Project">string [in] Name of project source file.</param>
/// <remarks>Does nothing if no project has been compiled.</remarks>
procedure DeleteObjFiles(const Path, Project: string);
/// <summary>Filters compiler output log and copies the result into a
/// string list.</summary>
/// <param name="Filter">TCompLogFilter [in] Indicates how the compiler log
/// is to be filtered.</param>
/// <param name="Lines">TStrings [in] String list that receives the lines
/// of the filtered log. May be empty.</param>
procedure Log(const Filter: TCompLogFilter; const Lines: TStrings);
overload;
/// <summary>Filters compiler output log using a filter of given type and
/// returns the result as a string with lines delimited by CRLF.</summary>
function Log(const Filter: TCompLogFilter): string;
overload;
/// <summary>Checks if last compilation resulted in an error or a warning.
/// </summary>
/// <remarks>Returns False if Compile method has not been called.</remarks>
function HasErrorsOrWarnings: Boolean;
/// <summary>Returns result of last compilation by this compiler.</summary>
/// <remarks>crQuery is returned if compiler is not available or if Compile
/// method has not been called.</remarks>
function GetLastCompileResult: TCompileResult;
end;
type
/// <summary>Interface implemented by objects that maintain a list of all
/// compilers supported by the program.</summary>
ICompilers = interface(IInterface)
['{39083768-2479-4F39-8473-0BDA381E1E81}']
/// <summary>Getter for Compilers property.</summary>
function GetCompiler(CompID: TCompilerID): ICompiler;
/// <summary>Getter for Count property.</summary>
function GetCount: Integer;
/// <summary>Getter for AvailableCount property.</summary>
function GetAvailableCount: Integer;
/// <summary>Finds the ID of the compiler with a given ID string.</summary>
/// <param name="IDStr">string [in] ID string of required compiler.</param>
/// <param name="ID">TCompilerID [out] Set to the ID of the compiler whose
/// ID string matches IDStr if found. Left undefined if no compiler is
/// found.</param>
/// <returns>Boolean. True if a compiler with the given ID string was
/// found or False if not.</returns>
/// <remarks>The search for the ID string is not case sensitive.</remarks>
function GetIDFromString(const IDStr: string; out ID: TCompilerID): Boolean;
/// <summary>Creates and returns an enumerator for all compilers in this
/// object.</summary>
function GetEnumerator: TEnumerator<ICompiler>;
/// <summary>List of all compilers supported by the program.</summary>
/// <remarks>Ths list is indexed by compiler ID.</remarks>
property Compilers[Ver: TCompilerID]: ICompiler
read GetCompiler; default;
{List of all compilers supported by the program, indexed by compiler id}
/// <summary>Number of compilers in list.</summary>
property Count: Integer read GetCount;
/// <summary>Number of compilers installed on this computer and made
/// available CodeSnip.</summary>
property AvailableCount: Integer read GetAvailableCount;
/// <summary>Checks if any compilers in the list are displayable.</summary>
function HaveDisplayable: Boolean;
end;
type
/// <summary>Iterface supported by objects that can save and load an
/// ICompilers object to and from persistent storage.</summary>
IPersistCompilers = interface(IInterface)
['{76A78863-5B95-4ECA-9295-75A98994EFA5}']
/// <summary>Saves the given list of compilers to persistent storage.
/// </summary>
procedure Save(const Compilers: ICompilers);
/// <summary>Loads given list of compiler from storage, overwriting any
/// existing previous content.</summary>
procedure Load(const Compilers: ICompilers);
end;
type
/// <summary>Interface supported by compiler objects that can detect their
/// own executable file path.</summary>
ICompilerAutoDetect = interface(IInterface)
['{62FE97CE-4616-406B-A9C2-D4B3BC751936}']
/// <summary>Detects and records the full path of the compiler's
/// executable.</summary>
function DetectExeFile: Boolean;
end;
implementation
end.
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.