pierre 582699aec8 --- Merging r16056 into '.': vor 15 Jahren
..
alpha a23fa2e81e * moved (unfinished) routines related to writing taicpu's to ppu files vor 18 Jahren
arm cf2ecd6d55 --- Merging r14114 into '.': vor 15 Jahren
avr 16715b7948 --- Merging r13695 into '.': vor 15 Jahren
html fa0d3d79e0 no message vor 23 Jahren
i386 75b5b6c74d --- Merging r13785 into '.': vor 15 Jahren
ia64 32098ceea9 * first iA-64 register stuff vor 19 Jahren
m68k 34c985cfa6 * added register type parameter to cgsize2subreg(), as the subreg can vor 16 Jahren
mips 491f0fa1d8 * Replaced all user defined warnings by TODO comments to reduce compiler noise. vor 17 Jahren
msg f0f3eb9040 -- Zusammenführen von r14009 in ».«: vor 15 Jahren
powerpc 75b5b6c74d --- Merging r13785 into '.': vor 15 Jahren
powerpc64 cf2ecd6d55 --- Merging r14114 into '.': vor 15 Jahren
ppcgen 16715b7948 --- Merging r13695 into '.': vor 15 Jahren
sparc 75b5b6c74d --- Merging r13785 into '.': vor 15 Jahren
systems 582699aec8 --- Merging r16056 into '.': vor 15 Jahren
utils 92c7840b62 Update Makefiles with recent fpcmake vor 15 Jahren
vis b7fe6797bf Merged revisions 2921-2922,2925 via svnmerge from vor 19 Jahren
x86 dd6900c7c0 --- Merging r14690 into '.': vor 15 Jahren
x86_64 cf2ecd6d55 --- Merging r14114 into '.': vor 15 Jahren
COPYING.txt 4bf254bc32 * added .txt extensions to all README, TODO and COPYING files vor 16 Jahren
MPWMake 05d6f0e94d macos: added a fake sysutils for use by compiler, and fixed some tests vor 19 Jahren
Makefile 92c7840b62 Update Makefiles with recent fpcmake vor 15 Jahren
Makefile.fpc d99dfe58e4 * fixes branch to 2.4.3 vor 15 Jahren
README.txt 4bf254bc32 * added .txt extensions to all README, TODO and COPYING files vor 16 Jahren
aasmbase.pas 16715b7948 --- Merging r13695 into '.': vor 15 Jahren
aasmdata.pas d89154a6b2 - disabled Objective-C support (basically only support for the objcselector vor 16 Jahren
aasmsym.pas a23fa2e81e * moved (unfinished) routines related to writing taicpu's to ppu files vor 18 Jahren
aasmtai.pas 75b5b6c74d --- Merging r13785 into '.': vor 15 Jahren
aggas.pas 75b5b6c74d --- Merging r13785 into '.': vor 15 Jahren
aopt.pas 75b5b6c74d --- Merging r13785 into '.': vor 15 Jahren
aoptbase.pas f97730f73f * use labelCanBeSkipped as used by i386 in generic optimizer code too vor 16 Jahren
aoptcs.pas b7fe6797bf Merged revisions 2921-2922,2925 via svnmerge from vor 19 Jahren
aoptda.pas 1f6ec379de * moved field definitions before method/property definitions (see mantis vor 16 Jahren
aoptobj.pas 75b5b6c74d --- Merging r13785 into '.': vor 15 Jahren
assemble.pas 582699aec8 --- Merging r16056 into '.': vor 15 Jahren
browcol.pas 2635212ebc * fixed warnings and removed unused "Current_moduleIndex" global variable vor 16 Jahren
bsdcompile 26081ed999 * Simple script which specifies the right params for a try out BSD build vor 25 Jahren
catch.pas fd070544db - disabled installation of SIGINT signal handler for Darwin, because vor 16 Jahren
ccharset.pas b178b08ba7 Merged revisions 11665-11738 via svnmerge from vor 17 Jahren
cclasses.pas 8887c34515 --- Reverse-merging r14244 into '.': vor 15 Jahren
cfidwarf.pas 491f0fa1d8 * Replaced all user defined warnings by TODO comments to reduce compiler noise. vor 17 Jahren
cfileutl.pas 75b5b6c74d --- Merging r13785 into '.': vor 15 Jahren
cg64f32.pas 7d459cf12a * the compiler now explicitly keeps track of the minimally guaranteed vor 16 Jahren
cgbase.pas 16715b7948 --- Merging r13695 into '.': vor 15 Jahren
cgobj.pas 53d60f02b2 * lying around newline fixes vor 16 Jahren
cgutils.pas 67cb961ed3 * only x86 and m68k need treference.segment vor 16 Jahren
cmsgs.pas 64ddae4eff + -vq parameter to show message numbers vor 17 Jahren
comphook.pas 64ddae4eff + -vq parameter to show message numbers vor 17 Jahren
compiler.pas 060d81b8fa Merged revisions 11878,11881-11882,11889,11891-11893,11895,11899-11902,11935,11938,12212,12304,12308-12310,12316,12330-12332,12334,12339-12340 via svnmerge from vor 16 Jahren
compinnr.inc d89154a6b2 - disabled Objective-C support (basically only support for the objcselector vor 16 Jahren
comprsrc.pas de658fe5d2 --- Merging r14969 into '.': vor 15 Jahren
constexp.pas 75b5b6c74d --- Merging r13785 into '.': vor 15 Jahren
cp1251.pas b178b08ba7 Merged revisions 11665-11738 via svnmerge from vor 17 Jahren
cp437.pas b178b08ba7 Merged revisions 11665-11738 via svnmerge from vor 17 Jahren
cp850.pas b178b08ba7 Merged revisions 11665-11738 via svnmerge from vor 17 Jahren
cp866.pas b178b08ba7 Merged revisions 11665-11738 via svnmerge from vor 17 Jahren
cp8859_1.pas b178b08ba7 Merged revisions 11665-11738 via svnmerge from vor 17 Jahren
cp8859_5.pas b178b08ba7 Merged revisions 11665-11738 via svnmerge from vor 17 Jahren
crefs.pas a039dd6942 * Fixed warnings about hiding inherited method. vor 17 Jahren
cresstr.pas 0698121f36 --- Merging r13526 into '.': vor 16 Jahren
cstreams.pas 71193c0f2c * fixed bootstrapping with 2.0.4 vor 18 Jahren
cutils.pas ea2fc88f80 --- Merging r13550 into '.': vor 16 Jahren
dbgbase.pas a3a66ba74d * split tvisibility from tsymoptions vor 17 Jahren
dbgdwarf.pas 75b5b6c74d --- Merging r13785 into '.': vor 15 Jahren
dbgstabs.pas 08fe975099 Skipped 'tests/tbs/tb0565.pp' vor 15 Jahren
defcmp.pas 3a8b29be91 + test conversion from class to differently sized enum and to differently vor 16 Jahren
defutil.pas dd6900c7c0 --- Merging r14690 into '.': vor 15 Jahren
export.pas 150eda304b * factored unix exports handling from t_bsd and t_linux into expunix unit vor 17 Jahren
expunix.pas 443ff1dfdf --- Merging r14241 into '.': vor 15 Jahren
finput.pas 0698121f36 --- Merging r13526 into '.': vor 16 Jahren
fmodule.pas fa2533759e * largely undid merge of r14503, because it creates more problems (compiler vor 15 Jahren
fpccrc.pas 793fd8fc09 * Add -Xg to help pages vor 17 Jahren
fpcdefs.inc be43cec33a * enable cross-compiling from x86_64 platforms that support the extended vor 16 Jahren
fppu.pas fa2533759e * largely undid merge of r14503, because it creates more problems (compiler vor 15 Jahren
gendef.pas caf0096877 * enabled version and description directive for all windows vor 16 Jahren
globals.pas 75b5b6c74d --- Merging r13785 into '.': vor 15 Jahren
globtype.pas f3caaa6903 --- Merging r14221 into '.': vor 15 Jahren
htypechk.pas 8aa9b77592 --- Merging r15918 into '.': vor 15 Jahren
impdef.pas f1067607b6 + workaround for non-working dircache on morphos/amiga vor 18 Jahren
import.pas bf1c390027 * refactor import library generation vor 19 Jahren
link.pas 1f6ec379de * moved field definitions before method/property definitions (see mantis vor 16 Jahren
msgidx.inc f0f3eb9040 -- Zusammenführen von r14009 in ».«: vor 15 Jahren
msgtxt.inc f0f3eb9040 -- Zusammenführen von r14009 in ».«: vor 15 Jahren
nadd.pas dd6900c7c0 --- Merging r14690 into '.': vor 15 Jahren
nbas.pas 060bdbcb47 * fix writing of goto node to ppu vor 17 Jahren
ncal.pas dd6900c7c0 --- Merging r14690 into '.': vor 15 Jahren
ncgadd.pas 8f239d04b6 * cleanup and simplify the set type handling vor 17 Jahren
ncgbas.pas 78e19bdd0b --- Merging r14468 into '.': vor 15 Jahren
ncgcal.pas 16715b7948 --- Merging r13695 into '.': vor 15 Jahren
ncgcnv.pas dd6900c7c0 --- Merging r14690 into '.': vor 15 Jahren
ncgcon.pas 75b5b6c74d --- Merging r13785 into '.': vor 15 Jahren
ncgflw.pas 75b5b6c74d --- Merging r13785 into '.': vor 15 Jahren
ncginl.pas 7cce96aaba --- Merging r14260 into '.': vor 15 Jahren
ncgld.pas cc44257086 * made internalerror unique vor 16 Jahren
ncgmat.pas 718694d1d6 * always specify an explicit alignment for tgobj.gettemp (so e.g. vor 17 Jahren
ncgmem.pas dd6900c7c0 --- Merging r14690 into '.': vor 15 Jahren
ncgopt.pas 7d459cf12a * the compiler now explicitly keeps track of the minimally guaranteed vor 16 Jahren
ncgrtti.pas 580f9b6435 --- Merging r13548 through r13549 into '.': vor 16 Jahren
ncgset.pas 75b5b6c74d --- Merging r13785 into '.': vor 15 Jahren
ncgutil.pas dd6900c7c0 --- Merging r14690 into '.': vor 15 Jahren
ncnv.pas dd6900c7c0 --- Merging r14690 into '.': vor 15 Jahren
ncon.pas 78e19bdd0b --- Merging r14468 into '.': vor 15 Jahren
nflw.pas 56531ae398 merge revisions: r14008,r14041,r14042,r14043,r14044,r14045,r14065,r14067,r14087,r14088,r14093,r14095,r14171: vor 15 Jahren
ninl.pas 78e19bdd0b --- Merging r14468 into '.': vor 15 Jahren
nld.pas 49cff00793 * unified ie vor 16 Jahren
nmat.pas a00df1033f * changed "Mixing signed expressions and longwords gives a 64bit result" vor 17 Jahren
nmem.pas 8aa9b77592 --- Merging r15918 into '.': vor 15 Jahren
nobj.pas 83cbf578c3 --- Merging r14005 into '.': vor 15 Jahren
node.pas d89154a6b2 - disabled Objective-C support (basically only support for the objcselector vor 16 Jahren
nopt.pas 6b8aed593f * remove registers{int/mmx/fpu} from firstpass vor 18 Jahren
nset.pas 060bdbcb47 * fix writing of goto node to ppu vor 17 Jahren
nstate.pas 790a4fe2d3 * log and id tags removed vor 20 Jahren
nutils.pas dd6900c7c0 --- Merging r14690 into '.': vor 15 Jahren
ogbase.pas d89154a6b2 - disabled Objective-C support (basically only support for the objcselector vor 16 Jahren
ogcoff.pas 582699aec8 --- Merging r16056 into '.': vor 15 Jahren
ogelf.pas fb3d2660b3 --- Merging r14224 into '.': vor 15 Jahren
oglx.pas 658c46b903 * remove tdictionary and tindexarray vor 19 Jahren
ogmap.pas 5e11e697b4 * Use unsigned integers for sizes and positions to break 2GB limit in tdynamicarray, object writer, internal linker, coff and PE headers. vor 17 Jahren
optbase.pas 15b0711ca0 * various optimizations by Dave Richards (mantis #12440) vor 16 Jahren
optcse.pas 8db40851c0 * fixed some crashes vor 18 Jahren
optdead.pas 1597aac6d2 * first search for gnm and only then for nm vor 16 Jahren
optdfa.pas a537134603 * set result of ResetDFA, resolves #12757 vor 16 Jahren
options.pas 56531ae398 merge revisions: r14008,r14041,r14042,r14043,r14044,r14045,r14065,r14067,r14087,r14088,r14093,r14095,r14171: vor 15 Jahren
optloop.pas 5e448b47a5 * compilation fixed vor 17 Jahren
opttail.pas 6434772c3c * error message when a goto label is optimized away vor 18 Jahren
optutils.pas db196d76c2 + strength reduction for array accesses inside for loops vor 17 Jahren
optvirt.pas ea2fc88f80 --- Merging r13550 into '.': vor 16 Jahren
owar.pas 5e11e697b4 * Use unsigned integers for sizes and positions to break 2GB limit in tdynamicarray, object writer, internal linker, coff and PE headers. vor 17 Jahren
owbase.pas 5e11e697b4 * Use unsigned integers for sizes and positions to break 2GB limit in tdynamicarray, object writer, internal linker, coff and PE headers. vor 17 Jahren
parabase.pas 7d459cf12a * the compiler now explicitly keeps track of the minimally guaranteed vor 16 Jahren
paramgr.pas 16715b7948 --- Merging r13695 into '.': vor 15 Jahren
parser.pas 04402dd6cc * initialize allow_array_constructor for each compilation run, fixes probably #12283 vor 16 Jahren
pass_1.pas 347c90070f --- Merging r13756 into '.': vor 15 Jahren
pass_2.pas 80c0f33c0e * patch by Sergei Gorelkin: fixes compilation with -dEXTDEBUG vor 16 Jahren
pbase.pas 18ad138f45 merge r13997: vor 15 Jahren
pdecl.pas 18ad138f45 merge r13997: vor 15 Jahren
pdecobj.pas 75b5b6c74d --- Merging r13785 into '.': vor 15 Jahren
pdecsub.pas 78e19bdd0b --- Merging r14468 into '.': vor 15 Jahren
pdecvar.pas dd6900c7c0 --- Merging r14690 into '.': vor 15 Jahren
pexports.pas eb130d7501 * fixed invalid type cast in case of errors in a library's export section vor 17 Jahren
pexpr.pas 78e19bdd0b --- Merging r14468 into '.': vor 15 Jahren
pinline.pas 6a6a6a6e6f * Copy() with WideChar array or PWideChar parameter should use fpc_unicodestr_copy compilerproc, since fpc_widestr_copy is available only on Windows. Bug #14307. vor 16 Jahren
pmodules.pas fa2533759e * largely undid merge of r14503, because it creates more problems (compiler vor 15 Jahren
pp.lpi 56531ae398 merge revisions: r14008,r14041,r14042,r14043,r14044,r14045,r14065,r14067,r14087,r14088,r14093,r14095,r14171: vor 15 Jahren
pp.pas 6e8a6790d1 + FPC_ARMEB and CPUARMEB similiar to FPC_ARMEL and CPUARMEL vor 16 Jahren
ppc.cfg 9465a13e71 + Delphi 6 configuration file vor 23 Jahren
ppc.conf add30a428e * Kylix fixes, mostly case names of units vor 24 Jahren
ppc.dof 67486c96c3 * fixes for Delphi 6 compilation vor 23 Jahren
ppc68k.lpi ab217ca748 * lpi version increased vor 16 Jahren
ppcarm.lpi ab217ca748 * lpi version increased vor 16 Jahren
ppcavr.lpi ab217ca748 * lpi version increased vor 16 Jahren
ppcppc.lpi ab217ca748 * lpi version increased vor 16 Jahren
ppcsparc.lpi ab217ca748 * lpi version increased vor 16 Jahren
ppheap.pas ef7bd58c54 * germanism removed (aktfilepos -> current_filepos) vor 19 Jahren
ppu.pas fa2533759e * largely undid merge of r14503, because it creates more problems (compiler vor 15 Jahren
ppx86_64.lpi ab217ca748 * lpi version increased vor 16 Jahren
procinfo.pas 7d459cf12a * the compiler now explicitly keeps track of the minimally guaranteed vor 16 Jahren
pstatmnt.pas 78e19bdd0b --- Merging r14468 into '.': vor 15 Jahren
psub.pas 18ad138f45 merge r13997: vor 15 Jahren
psystem.pas d89154a6b2 - disabled Objective-C support (basically only support for the objcselector vor 16 Jahren
ptconst.pas 18ad138f45 merge r13997: vor 15 Jahren
ptype.pas ea2fc88f80 --- Merging r13550 into '.': vor 16 Jahren
raatt.pas cc911887a8 * undo accidently committed changes from r11398 vor 17 Jahren
rabase.pas b7fe6797bf Merged revisions 2921-2922,2925 via svnmerge from vor 19 Jahren
rasm.pas 1684a6fc32 * replaced tdictionary with tfphashlist vor 19 Jahren
rautils.pas 10158da60e * give an error when trying to use the offset of a non-byte-aligned field vor 16 Jahren
regvars.pas 491f0fa1d8 * Replaced all user defined warnings by TODO comments to reduce compiler noise. vor 17 Jahren
rescmn.pas 174de3eab1 Merged revisions 9693-10480 via svnmerge from vor 17 Jahren
rgbase.pas 790a4fe2d3 * log and id tags removed vor 20 Jahren
rgobj.pas 75b5b6c74d --- Merging r13785 into '.': vor 15 Jahren
scandir.pas caf0096877 * enabled version and description directive for all windows vor 16 Jahren
scanner.pas 75b5b6c74d --- Merging r13785 into '.': vor 15 Jahren
script.pas 446e2161ce + Made a single Amiga/MorphOS-specific PathConv import to cfileutl.pas, instead of importing it every single place it is needed. vor 16 Jahren
switches.pas a7e02c7948 * check validity of calling conventions specified using {$calling x} vor 16 Jahren
symbase.pas a3a66ba74d * split tvisibility from tsymoptions vor 17 Jahren
symconst.pas 18ad138f45 merge r13997: vor 15 Jahren
symdef.pas fa2533759e * largely undid merge of r14503, because it creates more problems (compiler vor 15 Jahren
symnot.pas 790a4fe2d3 * log and id tags removed vor 20 Jahren
symsym.pas 347c90070f --- Merging r13756 into '.': vor 15 Jahren
symtable.pas 56531ae398 merge revisions: r14008,r14041,r14042,r14043,r14044,r14045,r14065,r14067,r14087,r14088,r14093,r14095,r14171: vor 15 Jahren
symtype.pas 18ad138f45 merge r13997: vor 15 Jahren
symutil.pas 9adb202a92 * Rework the constexprint to allow operations from low(int64) to high(qword). vor 18 Jahren
systems.pas 70ba9f69bb --- Merging r14401 into '.': vor 15 Jahren
tgobj.pas 718694d1d6 * always specify an explicit alignment for tgobj.gettemp (so e.g. vor 17 Jahren
tokens.pas beeb2e1374 merge r13938: vor 15 Jahren
verbose.pas 75b5b6c74d --- Merging r13785 into '.': vor 15 Jahren
version.pas d99dfe58e4 * fixes branch to 2.4.3 vor 15 Jahren
widestr.pas 78e19bdd0b --- Merging r14468 into '.': vor 15 Jahren
wpo.pas 060d81b8fa Merged revisions 11878,11881-11882,11889,11891-11893,11895,11899-11902,11935,11938,12212,12304,12308-12310,12316,12330-12332,12334,12339-12340 via svnmerge from vor 16 Jahren
wpobase.pas 7bff50becd * give an error message when the specified wpo feedback input file vor 16 Jahren
wpoinfo.pas fa2533759e * largely undid merge of r14503, because it creates more problems (compiler vor 15 Jahren

README.txt

This directory contains the sources of the Free Pascal Compiler

If you want to compile/modify the compiler, please read first the
programmers manual.

To recompile the compiler, you can use the batch files :
+ mppc386.bat if you want to build a cross compiler from i386 to m68k
+ mppcsparc if you want to build a cross compiler from i386 to SPARC

or
Use the make utility as following

make OS_TARGET="compiler OS target" \
CPU_TARGET="compiler CPU target" \
FPCCPUOPT="Optimization level" \
PP="compiler used to compile FPC" \
COMPILER_OPTIONS="Options passed to compiler" \


If an option is omitted, then target CPU/OS will be same as current CPU/OS

Possibles targets are : linux go32v2 win32 os2 freebsd beos netbsd amiga haiku
atari sunos qnx netware openbsd wdosx palmos macos macosx emx

Possible compiler switches (* marks a currently required switch):
-----------------------------------------------------------------
GDB* support of the GNU Debugger
I386 generate a compiler for the Intel i386+
x86_64 generate a compiler for the AMD x86-64 architecture
M68K generate a compiler for the M68000
SPARC generate a compiler for SPARC
POWERPC generate a compiler for the PowerPC
VIS generate a compile for the VIS
DEBUG version with debug code is generated
EXTDEBUG some extra debug code is executed
SUPPORT_MMX only i386: releases the compiler switch
MMX which allows the compiler to generate
MMX instructions
EXTERN_MSG Don't compile the msgfiles in the compiler, always
use external messagefiles, default for TP
NOAG386INT no Intel Assembler output
NOAG386NSM no NASM output
NOAG386BIN leaves out the binary writer, default for TP
NORA386DIR No direct i386 assembler reader
TEST_GENERIC Test Generic version of code generator
(uses generic RTL calls)
-----------------------------------------------------------------
cpuflags The target processor has status flags (on by default)
cpufpemu The target compiler will also support emitting software
floating point operations
cpu64bitaddr The targets use a 64-bit address space (pointers and
the default integer type are 64 bit)
cpu64bitalu The target cpu has 64-bit registers available (unless
cpu64bitaddr is also defined, pointers and default
integer type remain 32 bit, but the cpu can perform
64 bit calculations directly without needing helpers)
-----------------------------------------------------------------

Required switches for a i386 compiler be compiled by Free Pascal Compiler:
GDB;I386

to build a compiler to SPARC target using a Win32/i386 you just use :
make CPU_TARGET=SPARC