forked from castle-engine/castle-engine
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathcastle-fpc.cfg
463 lines (404 loc) · 13.7 KB
/
castle-fpc.cfg
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
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
410
411
412
413
414
415
416
417
418
419
420
421
422
423
424
425
426
427
428
429
430
431
432
433
434
435
436
437
438
439
440
441
442
443
444
445
446
447
448
449
450
451
452
453
454
455
456
457
458
459
460
461
462
463
# -*- mode: shell-script -*-
#
# FPC configuration file for Castle Game Engine.
#
# ------------------------------------------------------------------------
# When it is used?
#
# This file is only used in special compilation methods:
# - When compiling the build tool itself, using
# tools/build-tool/castle-engine_compile.sh
# tools/build-tool/castle-engine_compile.ps1
# - When using fpmake to build the engine
#
# Above are *not recommended* compilation methods for Castle Game Engine.
# Instead we recommend to build using:
# - Castle Game Engine editor https://castle-engine.io/editor
# - Castle Game Engine command-line build tool https://castle-engine.io/build_tool
# - Lazarus IDE
# - Delphi IDE
# Above compilation methods don't use this file.
# They call the compilers (like FPC or Delphi) with proper parameters under
# the hoood.
#
# ------------------------------------------------------------------------
# What does this define?
#
# Pretty much normal configuration for people that like modern ObjectPascal
# and ObjFpc mode.
#
# Accepts two switches: DEBUG and RELEASE. If you don't define any of them
# debug and optimizing code will be done according to compiler defaults.
# Never define both of them.
#
# Accepts a switch CASTLE_ENGINE_PATHS_ALREADY_DEFINED:
# in this case we will assume that proper -Fu and -Fi, to provide
# paths for FPC to our units, have already been defined.
# This allows to call FPC from any directory (otherwise you have to call
# FPC from this directory, containing castle-fpc.cfg, to make relative paths
# here work).
# output options -------------------------------------------------------------
# Show FPC logo (shows fpc version)
-l
# Show warnings + notes.
# Do not show hints (there are too many useless hints produced by FPC).
-vwn
# Input/output checks always, even in release version.
# Some code may depend on the fact that IO errors in standard Pascal
# functions are checked automatically (and raise exceptions
# if SysUtils is compiled in). Although 99% of code should use TStream
# instead of old Pascal IO, and then this switch doesn't matter.
-Ci
# do not show Warning: (2045) APPTYPE is not supported by the target OS
-vm2045
# do not show Hint: (5024) Parameter "..." not used
-vm5024
# do not show
# Warning: Constructing a class "TCustomDictionaryEnumerator$4$crc6100464F" with abstract method "GetCurrent"
# Warning: Constructing a class "TCustomDictionaryEnumerator$4$crcBD4794B2" with abstract method "DoMoveNext"
# TODO: This is a pity, we also hide useful warnings this way.
# Submitted as https://bugs.freepascal.org/view.php?id=32142
-vm04046
#IFNDEF VER2
#IFNDEF VER3_0
# do not show Warning: Symbol "TArrayHelper$1" is experimental
# (only for FPC >= 3.1.1, for 3.0.x we fix this in our custom Generics.Collections unit)
# TODO: This is a pity, we also hide useful warnings this way.
-vm05063
# do not show
# Note: Private type "TCustomPointersEnumerator$2<CASTLEVECTORSINTERNALSINGLE.TGenericVector2,CASTLEVECTORS.TCustomList$1$crc1D7BB6F0.PT>.T" never used
-vm5071
#IFNDEF VER3_1
# do not show
# Note: Call to subroutine "function TGenericVector3.Length:Single;" marked as inline is not inlined
# (In FPC 3.3.1, not in FPC 3.1.1 rev 38027)
-vm6058
# do not show
# Warning: Local variable "$1" of a managed type does not seem to be initialized
# (a lot of false warnings since FPC 3.3.1)
-vm5089
# do not show
# Warning: Variable "OutputFace" of a managed type does not seem to be initialized
# (3 false warnings since FPC 3.3.1 in Kraft)
-vm5090
# do not show
# Warning: function result variable of a managed type does not seem to be initialized
# (a lot of false warnings since FPC 3.3.1)
-vm5093
#ENDIF
#ENDIF
#ENDIF
# syntax options --------------------------------------------------------
# Default syntax mode.
#
# Some reasons why we prefer -Mobjfpc (not -Mdelphi mode) in FPC:
#
# - There are some things strange in delphi mode, for compatibility with delphi/tp,
# that sometimes bite me (like the fact that in FPC >= 2.0.3
# Single(Integer) makes a variable typecast, not a value typecast).
# TODO: check is the above still true?
#
# - ObjFpc has some nice improvements:
#
# - Assigning procedural variables is better:
# "@" is required to get an address of a procedure,
# and assignment is always checked for parameter correctness.
# In Delphi mode @ may be omitted, and when it's
# not omitted, you can cheat and pass procedure with not matching params.
# Using {$TYPEDADDRESS ON} in Delphi (10.2) helps with this
# (but not in FPC Delphi mode).
#
# - Overloading without the "overload" keyword is often more sane:
# It's not cross-class and cross-unit. This allows to hide ancestor
# methods, while still defining multiple versions of them.
# It avoids a nasty trap of Delphi "overload" described
# at TNoParameterlessContructor documentation.
#
# - Check that method parameter names must differ from class
# fields/methods/properties names --- this is nice, saves you from some
# hard to spot bugs otherwise when renaming.
#
# - ObjFpc is preferred by Lazarus, suggested for new source code by Lazarus.
# So it is just something more familiar for people coming from FPC/Lazarus.
-Mobjfpc
# Enable macros
-Sm
# Enable C-like operators +=, -= etc.
-Sc
# Use ansistrings ("string" = "AnsiString")
-Sh
# Enable inline (although we sometimes surround it in {$ifdef SUPPORTS_INLINE} anyway)
-Si
# units/includes paths --------------------------------------------------
# It seems that FPC does not define symbol UNIX before reading config file,
# even though it defines LINUX (or FREEBSD; I assume that this is also
# the case with DARWIN).
# But I need symbol UNIX *now* to include paths common for all UNIXes.
#IFDEF LINUX
#DEFINE UNIX
#ENDIF
#IFDEF DARWIN
#DEFINE UNIX
#ENDIF
#IFDEF FREEBSD
#DEFINE UNIX
#ENDIF
# Looks like MSWINDOWS symbol needs to be fixed now, just like UNIX above.
#IFDEF WIN32
#DEFINE MSWINDOWS
#ENDIF
#IFDEF WIN64
#DEFINE MSWINDOWS
#ENDIF
#IFNDEF CASTLE_ENGINE_PATHS_ALREADY_DEFINED
# Common paths for all OSes
-Fusrc/base/
-Fisrc/base/
-Fisrc/common_includes/
-Fusrc/base_rendering/
-Fisrc/base_rendering/
-Fusrc/base_rendering/dglopengl/
-Fisrc/base_rendering/dglopengl/
-Fisrc/base_rendering/glsl/generated-pascal/
-Fusrc/fonts/
-Fisrc/fonts/
-Fusrc/window/
-Fisrc/window/
-Fusrc/window/deprecated_units/
-Fisrc/window/deprecated_units/
-Fisrc/window/gtk/
-Fusrc/images/
-Fisrc/images/
-Fusrc/transform/
-Fisrc/transform/
-Fusrc/transform/
-Fisrc/transform/
-Fusrc/scene/x3d/
-Fisrc/scene/x3d/
-Fusrc/scene/load/
-Fisrc/scene/load/
-Fusrc/scene/load/spine/
-Fisrc/scene/load/spine/
-Fusrc/scene/load/md3/
-Fisrc/scene/load/md3/
-Fusrc/scene/load/ifc/
-Fisrc/scene/load/ifc/
-Fusrc/scene/load/collada/
-Fisrc/scene/load/collada/
-Fusrc/scene/load/pasgltf/
-Fisrc/scene/load/pasgltf/
-Fusrc/scene/
-Fisrc/scene/
-Fisrc/scene/glsl/generated-pascal/
-Fusrc/audio/
-Fisrc/audio/
-Fusrc/audio/fmod/
-Fisrc/audio/fmod/
-Fusrc/audio/openal/
-Fisrc/audio/openal/
-Fusrc/audio/ogg_vorbis/
-Fisrc/audio/ogg_vorbis/
-Fusrc/files/
-Fisrc/files/
-Fusrc/castlescript/
-Fisrc/castlescript/
-Fusrc/ui/
-Fisrc/ui/
-Fusrc/services/
-Fisrc/services/
-Fusrc/services/steam/
-Fusrc/physics/
-Fisrc/physics/
-Fusrc/physics/kraft/
-Fisrc/physics/kraft/
-Fusrc/deprecated_units/
-Fisrc/deprecated_units/
#IFDEF UNIX
-Fusrc/base/unix/
-Fisrc/base/unix/
-Fusrc/window/unix/
-Fisrc/window/unix/
#ENDIF
#IFDEF MSWINDOWS
-Fusrc/base/windows/
-Fisrc/base/windows/
-Fusrc/window/windows/
-Fisrc/window/windows/
-Fusrc/ui/windows/
-Fisrc/ui/windows/
#ENDIF
#IFDEF ANDROID
-Fusrc/base/android/
-Fisrc/base/android/
#ENDIF
# Vampyre Imaging Library
-Fusrc/vampyre_imaginglib/src/Source
-Fusrc/vampyre_imaginglib/src/Source/JpegLib
-Fusrc/vampyre_imaginglib/src/Source/ZLib
-Fusrc/vampyre_imaginglib/src/Extras/Extensions
-Fusrc/vampyre_imaginglib/src/Extensions/J2KObjects
-Fusrc/vampyre_imaginglib/src/Extensions/LibTiff
-Fusrc/vampyre_imaginglib/src/Extensions
-Fisrc/vampyre_imaginglib/src/Source
-Fisrc/vampyre_imaginglib/src/Source/JpegLib
-Fisrc/vampyre_imaginglib/src/Source/ZLib
-Fisrc/vampyre_imaginglib/src/Extras/Extensions
-Fisrc/vampyre_imaginglib/src/Extensions/J2KObjects
-Fisrc/vampyre_imaginglib/src/Extensions/LibTiff
-Fisrc/vampyre_imaginglib/src/Extensions
-Flsrc/vampyre_imaginglib/src/Extensions/J2KObjects
-Flsrc/vampyre_imaginglib/src/Extensions/LibTiff/Compiled
# This section is useful only for LSP server reading castle-fpc.cfg
# (like our https://github.com/castle-engine/pascal-language-server ).
# These lines allow to search for units inside the additional paths.
# This allows to have code completion in code using
# e.g. CastleDialogs unit (like CGE editor) or CastleClientServer.
#IFDEF USE_UNITS_FROM_LSP
-Fisrc/lcl/
-Fusrc/lcl/
-Fusrc/delphi/
-Fisrc/delphi/
-Fusrc/files/indy/
-Fisrc/files/indy/
#ENDIF
#ENDIF
# others ---------------------------------------------------------------------
#IFDEF ANDROID
# See tools/build-tool/toolcompile.pas for more comments about Android options.
#IFDEF ARM
-CpARMV7A
# Necessary to work fast.
# It is possible to compile without this (in such case,
# also compile FPC RTL without this). But the engine will run much slower.
# See https://castle-engine.io/android-FAQ#notes-about-compiling-with-hard-floats--cfvfpv3 .
-CfVFPV3
#ENDIF
#ENDIF
# Link with Cocoa. This is necessary here to compile the build tool using
# tools/build-tool/castle-engine_compile.sh .
#IFDEF DARWIN
#IFDEF CPUX86_64
-k-framework
-kCocoa
#ENDIF
#ENDIF
# debug specific -------------------------------------------------
#IFDEF DEBUG
#WRITE Compiling Debug Version
# range checks
-Cr
# overflow checks
-Co
# Stack overflow checks.
#
# castle fails with stack checking errors on x86-64.
# Otherwise, works OK, so I guess it's FPC bug.
# TODO: make testcase and submit. For now, stack checking is not
# done on x86-64.
#
# It also causes failures on Android with pthread in castleandroidnativeappglue.pas.
#IFNDEF CPUX86_64
#IFNDEF ANDROID
-Ct
#ENDIF
#ENDIF
# assertions checks
-Sa
# virtual method table checks
-CR
# trash local variables (to detect uninitialized uses)
-gt
# debug info for gdb and browser.
-g
#-bl
# LineMode unit for backtraces with line info.
-gl
# HeapTrc unit to track memory leaks.
#
# -gh is not enabled by default, because
# it produces confusing output when the program exits with
# exception (like from ProgramBreak) or Halt: it will always show
# some leaked memory in this case. Indeed, FPC always leaks memory then,
# this is FPC problem (although harmless, since in this case OS
# will free this memory anyway).
#
# If you understand this, you can (and should) enable -gh and use
# it to catch memory leaks in your programs.
# There should be *no* memory leaks from Castle Game Engine
# when the program exits in a usual fashion.
#-gh
# We do not check pointer validity.
#
# We experimented with this, but it was a significant burden to make it work,
# as we interact with many external libraries.
# It would make many false errors (when we dereference memory allocated
# by other libraries, e.g. libpng or gtk). We were masking it by
#
# { We dereference here memory allocated with XXX, so pointer checks
# will make false errors. }
# {$checkpointer off}
# .... // here work with external library
# {$ifdef KAMBI_CHECK_POINTER}
# { Turn checkpointer back on }
# {$checkpointer on}
# {$endif}
#
# (We needed -dKAMBI_CHECK_POINTER for this trick, since {$ifopt checkpointer}
# doesn't work.)
# But this was error prone, so a lot of valid code could still report
# false errors, unless we would "sprinkle" the above constructions, with
# {$checkpointer off}, all around CGE code.
#
# Also, -gc for whole code makes it much slower.
#
# Note that -gc requires -gh because checking pointer
# validity is part of HeapTrc unit.
#-gc
#-dKAMBI_CHECK_POINTER
#ENDIF
# profiling ------------------------------------------------------------------
#
# Profiling options should be used without -dDEBUG,
# -dDEBUG code may be (slightly) slower in (slightly)
# different places because of debug checks (range, overflow, stack checks etc.).
#
# They generally should be used with -dRELEASE, as you want to profile
# program timings experienced by the user, although sometimes -dRELASE may cause
# optimizations that may obfuscate profiler output.
# So sometimes yoy may want to undefine both DEBUG and RELEASE.
# gprof
# -pg
# valgrind
#-gl
#-gv
# release specific -----------------------------------------------
#IFDEF DARWIN
#IFDEF CPUAARCH64
#WRITE Disabling FPC optimizations, known to be buggy on Darwin/aarch64
#DEFINE CASTLE_DISABLE_OPTIMIZATIONS
#ENDIF
#ENDIF
#IFDEF RELEASE
#WRITE Compiling Release Version
# optimize : level 2, faster code
#IFDEF CASTLE_DISABLE_OPTIMIZATIONS
-O-
#ELSE
-O2
#ENDIF
#-OG # obsolete, FPC optimizes for faster code always
# (Don't optimize for Pentium;
# 1. there are still some people with older i386 processors ?
# 2. these Pentium-specific optimizations don't seem to give *any*
# real improvement for my code (checked with rayhunter
# with FPC 1.0.10; TODO -- do some speed checks with FPC 2.0.0))
# Note: remember, if you enable it, wrap it in #IFDEF CPUI386
# -Op2
# (smartlink turned off because REALLY slows down compilation
# and doesn't reduce size of my programs too much)
#-CX
#-XX
# strip symbols from exe (symbols are used only in debugging)
-Xs
#ENDIF
# eof --------------------------------------------------------------------------