|
@@ -1,8417 +1,8561 @@
|
|
|
{$ifdef Delphi}
|
|
|
-const fpmkunitsrc : array[0..970] of string[240]=(
|
|
|
+const fpmkunitsrc : array[0..1001] of string[240]=(
|
|
|
{$else Delphi}
|
|
|
-const fpmkunitsrc : array[0..970,1..240] of char=(
|
|
|
+const fpmkunitsrc : array[0..1001,1..240] of char=(
|
|
|
{$endif Delphi}
|
|
|
- '{'#010+
|
|
|
- ' This file is part of the Free Pascal Makefile Package'#010+
|
|
|
- #010+
|
|
|
- ' Implementation of fpmake classes and functions'#010+
|
|
|
- #010+
|
|
|
- ' Copyright (c) 2007 by the freepascal team'#010+
|
|
|
- #010+
|
|
|
- ' See the file COPYING.FPC, included in this distribution,'#010+
|
|
|
- ' for details abo','ut the copyright.'#010+
|
|
|
- #010+
|
|
|
- ' This program is distributed in the hope that it will be useful,'#010+
|
|
|
- ' but WITHOUT ANY WARRANTY; without even the implied warranty of'#010+
|
|
|
- ' MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.'#010+
|
|
|
- #010+
|
|
|
- ' ***************************','****************************************'+
|
|
|
- '***}'#010+
|
|
|
- #010+
|
|
|
- 'unit fpmkunit;'#010+
|
|
|
- #010+
|
|
|
- '{$Mode objfpc}'#010+
|
|
|
- '{$H+}'#010+
|
|
|
- '{$inline on}'#010+
|
|
|
- #010+
|
|
|
+ '{'#013#010+
|
|
|
+ ' This file is part of the Free Pascal Makefile Package'#013#010+
|
|
|
+ #013#010+
|
|
|
+ ' Implementation of fpmake classes and functions'#013#010+
|
|
|
+ #013#010+
|
|
|
+ ' Copyright (c) 2007 by the freepascal team'#013#010+
|
|
|
+ #013#010+
|
|
|
+ ' See the file COPYING.FPC, included in this distribution,'#013#010+
|
|
|
+ ' for det','ails about the copyright.'#013#010+
|
|
|
+ #013#010+
|
|
|
+ ' This program is distributed in the hope that it will be useful,'#013+
|
|
|
+ #010+
|
|
|
+ ' but WITHOUT ANY WARRANTY; without even the implied warranty of'#013+
|
|
|
+ #010+
|
|
|
+ ' MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.'#013#010+
|
|
|
+ #013#010+
|
|
|
+ ' *************','******************************************************'+
|
|
|
+ '***}'#013#010+
|
|
|
+ #013#010+
|
|
|
+ 'unit fpmkunit;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ '{$Mode objfpc}'#013#010+
|
|
|
+ '{$H+}'#013#010+
|
|
|
+ '{$inline on}'#013#010+
|
|
|
+ #013#010+
|
|
|
'{ For target or cpu dependent dependencies also add an overload where '+
|
|
|
- 'you'#010+
|
|
|
- ' can pass only a set of cpus. This is disabled for now because it cr',
|
|
|
- 'eates'#010+
|
|
|
- ' an error in the compiler with overload choosing }'#010+
|
|
|
- '{ define cpu_only_overloads}'#010+
|
|
|
- #010+
|
|
|
- 'Interface'#010+
|
|
|
- #010+
|
|
|
- '{$IFDEF OS2}'#010+
|
|
|
- ' {$DEFINE NO_UNIT_PROCESS}'#010+
|
|
|
- '{$ENDIF OS2}'#010+
|
|
|
- #010+
|
|
|
- '{$IFDEF GO32V2}'#010+
|
|
|
- ' {$DEFINE NO_UNIT_PROCESS}'#010+
|
|
|
- '{$ENDIF GO32V2}'#010+
|
|
|
- #010+
|
|
|
- '{$IFDEF NETBSD}'#010+
|
|
|
- ' { NetBSD p','threads are not yet working, try to use fpmake without th'+
|
|
|
- 'reads }'#010+
|
|
|
- ' {$DEFINE NO_THREADING}'#010+
|
|
|
- '{$ENDIF NETBSD}'#010+
|
|
|
- #010+
|
|
|
- '{$ifndef NO_UNIT_PROCESS}'#010+
|
|
|
- ' {$define HAS_UNIT_PROCESS}'#010+
|
|
|
- '{$endif NO_UNIT_PROCESS}'#010+
|
|
|
- #010+
|
|
|
- '{$ifndef NO_UNIT_ZIPPER}'#010+
|
|
|
- ' {$define HAS_UNIT_ZIPPER}',#010+
|
|
|
- '{$endif NO_UNIT_ZIPPER}'#010+
|
|
|
- #010+
|
|
|
- 'uses'#010+
|
|
|
- '{$ifdef UNIX}'#010+
|
|
|
- ' BaseUnix,'#010+
|
|
|
- '{$endif UNIX}'#010+
|
|
|
- '{$ifndef NO_THREADING}'#010+
|
|
|
- '{$ifdef UNIX}'#010+
|
|
|
- ' cthreads,'#010+
|
|
|
- '{$endif UNIX}'#010+
|
|
|
- '{$endif NO_THREADING}'#010+
|
|
|
- ' SysUtils, Classes, StrUtils'#010+
|
|
|
- '{$ifdef HAS_UNIT_PROCESS}'#010+
|
|
|
- ' ,process'#010+
|
|
|
- '{$endif HAS_UNIT_','PROCESS}'#010+
|
|
|
- '{$ifdef HAS_UNIT_ZIPPER}'#010+
|
|
|
- ' ,zipper'#010+
|
|
|
- '{$endif HAS_UNIT_ZIPPER}'#010+
|
|
|
- ' ;'#010+
|
|
|
- #010+
|
|
|
- 'Type'#010+
|
|
|
+ 'you'#013#010+
|
|
|
+ ' can pass only a set of cpus. This is disable','d for now because it c'+
|
|
|
+ 'reates'#013#010+
|
|
|
+ ' an error in the compiler with overload choosing }'#013#010+
|
|
|
+ '{ define cpu_only_overloads}'#013#010+
|
|
|
+ #013#010+
|
|
|
+ 'Interface'#013#010+
|
|
|
+ #013#010+
|
|
|
+ '{$IFDEF OS2}'#013#010+
|
|
|
+ ' {$DEFINE NO_UNIT_PROCESS}'#013#010+
|
|
|
+ '{$ENDIF OS2}'#013#010+
|
|
|
+ #013#010+
|
|
|
+ '{$IFDEF GO32V2}'#013#010+
|
|
|
+ ' {$DEFINE NO_UNIT_PROCESS}'#013#010+
|
|
|
+ '{$ENDIF G','O32V2}'#013#010+
|
|
|
+ #013#010+
|
|
|
+ '{$IFDEF NETBSD}'#013#010+
|
|
|
+ ' { NetBSD pthreads are not yet working, try to use fpmake without thre'+
|
|
|
+ 'ads }'#013#010+
|
|
|
+ ' {$DEFINE NO_THREADING}'#013#010+
|
|
|
+ '{$ENDIF NETBSD}'#013#010+
|
|
|
+ #013#010+
|
|
|
+ '{$ifndef NO_UNIT_PROCESS}'#013#010+
|
|
|
+ ' {$define HAS_UNIT_PROCESS}'#013#010+
|
|
|
+ '{$endif NO_UNIT_PROCESS}'#013#010+
|
|
|
+ #013#010+
|
|
|
+ '{$ifnd','ef NO_UNIT_ZIPPER}'#013#010+
|
|
|
+ ' {$define HAS_UNIT_ZIPPER}'#013#010+
|
|
|
+ '{$endif NO_UNIT_ZIPPER}'#013#010+
|
|
|
+ #013#010+
|
|
|
+ 'uses'#013#010+
|
|
|
+ '{$ifdef UNIX}'#013#010+
|
|
|
+ ' BaseUnix,'#013#010+
|
|
|
+ '{$endif UNIX}'#013#010+
|
|
|
+ '{$ifndef NO_THREADING}'#013#010+
|
|
|
+ '{$ifdef UNIX}'#013#010+
|
|
|
+ ' cthreads,'#013#010+
|
|
|
+ '{$endif UNIX}'#013#010+
|
|
|
+ '{$endif NO_THREADING}'#013#010+
|
|
|
+ ' SysUtils, Classes, StrU','tils'#013#010+
|
|
|
+ '{$ifdef HAS_UNIT_PROCESS}'#013#010+
|
|
|
+ ' ,process'#013#010+
|
|
|
+ '{$endif HAS_UNIT_PROCESS}'#013#010+
|
|
|
+ '{$ifdef HAS_UNIT_ZIPPER}'#013#010+
|
|
|
+ ' ,zipper'#013#010+
|
|
|
+ '{$endif HAS_UNIT_ZIPPER}'#013#010+
|
|
|
+ ' ;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ 'Type'#013#010+
|
|
|
' TFileType = (ftSource,ftUnit,ftObject,ftResource,ftExecutable,ftStat'+
|
|
|
- 'icLibrary,'#010+
|
|
|
- ' ftSharedLibrary);'#010+
|
|
|
- ' TFileTypes = set of TFileType;'#010+
|
|
|
- #010+
|
|
|
- ' // Please k','eep this order, see OSCPUSupported below'#010+
|
|
|
- ' TCpu=(cpuNone,'#010+
|
|
|
- ' i386,m68k,powerpc,sparc,x86_64,arm,powerpc64,avr,armeb,'#010+
|
|
|
- ' mips,mipsel,jvm'#010+
|
|
|
- ' );'#010+
|
|
|
- ' TCPUS = Set of TCPU;'#010+
|
|
|
- #010+
|
|
|
- ' // Please keep this order, see OSCPUSupported below'#010+
|
|
|
- ' TOS=(osNone,'#010+
|
|
|
- ' ','linux,go32v2,win32,os2,freebsd,beos,netbsd,'#010+
|
|
|
- ' amiga,atari, solaris, qnx, netware, openbsd,wdosx,'#010+
|
|
|
- ' palmos,macos,darwin,emx,watcom,morphos,netwlibc,'#010+
|
|
|
- ' win64,wince,gba,nds,embedded,symbian,haiku,iphonesim,'#010+
|
|
|
- ' aix,java,android,nativent'#010,
|
|
|
- ' );'#010+
|
|
|
- ' TOSes = Set of TOS;'#010+
|
|
|
- #010+
|
|
|
- ' TCompilerMode = (cmFPC,cmTP,cmObjFPC,cmDelphi,cmMacPas);'#010+
|
|
|
- ' TCompilerModes = Set of TCompilerMode;'#010+
|
|
|
- #010+
|
|
|
- ' TTargetType = (ttProgram,ttUnit,ttImplicitUnit,ttCleanOnlyUnit,ttExa'+
|
|
|
- 'mpleUnit,ttExampleProgram,ttFPDoc);'#010+
|
|
|
- ' TTa','rgetTypes = set of TTargetType;'#010+
|
|
|
- #010+
|
|
|
+ 'icLibrary,'#013#010+
|
|
|
+ ' ',' ftSharedLibrary);'#013#010+
|
|
|
+ ' TFileTypes = set of TFileType;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ ' // Please keep this order, see OSCPUSupported below'#013#010+
|
|
|
+ ' TCpu=(cpuNone,'#013#010+
|
|
|
+ ' i386,m68k,powerpc,sparc,x86_64,arm,powerpc64,avr,armeb,'#013#010+
|
|
|
+ ' mips,mipsel,jvm'#013#010+
|
|
|
+ ' );'#013#010+
|
|
|
+ ' TCPUS = Set of TC','PU;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ ' // Please keep this order, see OSCPUSupported below'#013#010+
|
|
|
+ ' TOS=(osNone,'#013#010+
|
|
|
+ ' linux,go32v2,win32,os2,freebsd,beos,netbsd,'#013#010+
|
|
|
+ ' amiga,atari, solaris, qnx, netware, openbsd,wdosx,'#013#010+
|
|
|
+ ' palmos,macos,darwin,emx,watcom,morphos,netwlibc,'#013#010+
|
|
|
+ ' ',' win64,wince,gba,nds,embedded,symbian,haiku,iphonesim,'#013#010+
|
|
|
+ ' aix,java,android,nativent'#013#010+
|
|
|
+ ' );'#013#010+
|
|
|
+ ' TOSes = Set of TOS;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ ' TCompilerMode = (cmFPC,cmTP,cmObjFPC,cmDelphi,cmMacPas);'#013#010+
|
|
|
+ ' TCompilerModes = Set of TCompilerMode;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ ' TTargetType = (t','tProgram,ttUnit,ttImplicitUnit,ttCleanOnlyUnit,ttE'+
|
|
|
+ 'xampleUnit,ttExampleProgram,ttFPDoc);'#013#010+
|
|
|
+ ' TTargetTypes = set of TTargetType;'#013#010+
|
|
|
+ #013#010+
|
|
|
' TFPDocFormat = (ffHtml, ffHtm, ffXHtml, ffLaTex, ffXMLStruct, ffChm)'+
|
|
|
- ';'#010+
|
|
|
- ' TFPDocFormats = set of TFPDocFormat;'#010+
|
|
|
- #010+
|
|
|
+ ';'#013#010+
|
|
|
+ ' TFPDocFormats = set of TFPDocFormat;',#013#010+
|
|
|
+ #013#010+
|
|
|
' TTargetState = (tsNeutral,tsConsidering,tsNoCompile,tsCompiled,tsIns'+
|
|
|
- 'talled,tsNotFound);'#010+
|
|
|
- ' TTa','rgetStates = Set of TTargetState;'#010+
|
|
|
- #010+
|
|
|
- ' TSourceType = (stDoc,stSrc,stExample,stTest);'#010+
|
|
|
- ' TSourceTypes = set of TSourceType;'#010+
|
|
|
- #010+
|
|
|
- ' TVerboseLevel = (vlError,vlWarning,vlInfo,vldebug,vlCommand);'#010+
|
|
|
- ' TVerboseLevels = Set of TVerboseLevel;'#010+
|
|
|
- #010+
|
|
|
- ' TCommandAt ','= (caBeforeCompile,caAfterCompile,'#010+
|
|
|
- ' caBeforeInstall,caAfterInstall,'#010+
|
|
|
- ' caBeforeArchive,caAfterArchive,'#010+
|
|
|
- ' caBeforeClean,caAfterClean,'#010+
|
|
|
- ' caBeforeDownload,caAfterDownload);'#010+
|
|
|
- #010+
|
|
|
- ' TDependency','Type = (depPackage,depImplicitPackage,depUnit,depInclud'+
|
|
|
- 'e);'#010+
|
|
|
- ' TDependencyTypes = set of TDependencyType;'#010+
|
|
|
- #010+
|
|
|
- ' TLogEvent = Procedure (Level : TVerboseLevel; Const Msg : String) of'+
|
|
|
- ' Object;'#010+
|
|
|
- ' TNotifyProcEvent = procedure(Sender: TObject);'#010+
|
|
|
- #010+
|
|
|
- ' TRun','Mode = (rmCompile,rmBuild,rmInstall,rmArchive,rmClean,rmDistCl'+
|
|
|
- 'ean,rmManifest,rmZipInstall);'#010+
|
|
|
- #010+
|
|
|
- ' TBuildMode = (bmOneByOne, bmBuildUnit{, bmSkipImplicitUnits});'#010+
|
|
|
- ' TBuildModes = set of TBuildMode;'#010+
|
|
|
- ' TProcessPackageResult = (ppHandled, ppDelayed',');'#010+
|
|
|
+ 'talled,tsNotFound);'#013#010+
|
|
|
+ ' TTargetStates = Set of TTargetState;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ ' TSourceType = (stDoc,stSrc,stExample,stTest);'#013#010+
|
|
|
+ ' TSourceTypes = set of TSourceType;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ ' TVerboseLeve','l = (vlError,vlWarning,vlInfo,vldebug,vlCommand);'#013#010+
|
|
|
+ ' TVerboseLevels = Set of TVerboseLevel;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ ' TCommandAt = (caBeforeCompile,caAfterCompile,'#013#010+
|
|
|
+ ' caBeforeInstall,caAfterInstall,'#013#010+
|
|
|
+ ' caBeforeArchive,caAfterArchive,',#013#010+
|
|
|
+ ' caBeforeClean,caAfterClean,'#013#010+
|
|
|
+ ' caBeforeDownload,caAfterDownload);'#013#010+
|
|
|
+ #013#010+
|
|
|
+ ' TDependencyType = (depPackage,depImplicitPackage,depUnit,depInclude)'+
|
|
|
+ ';'#013#010+
|
|
|
+ ' TDependencyTypes = set of TDependencyType;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ ' TLogEvent = Proc','edure (Level : TVerboseLevel; Const Msg : String) '+
|
|
|
+ 'of Object;'#013#010+
|
|
|
+ ' TNotifyProcEvent = procedure(Sender: TObject);'#013#010+
|
|
|
+ #013#010+
|
|
|
+ ' TRunMode = (rmCompile,rmBuild,rmInstall,rmArchive,rmClean,rmDistClea'+
|
|
|
+ 'n,rmManifest,rmZipInstall);'#013#010+
|
|
|
+ #013#010+
|
|
|
+ ' TBuildMode = (bmOneByOn','e, bmBuildUnit{, bmSkipImplicitUnits});'#013+
|
|
|
+ #010+
|
|
|
+ ' TBuildModes = set of TBuildMode;'#013#010+
|
|
|
+ ' TProcessPackageResult = (ppHandled, ppDelayed);'#013#010+
|
|
|
' TCheckDependencyResult = (cdAvailable, cdNotAvailable, cdNotYetAvail'+
|
|
|
- 'able);'#010+
|
|
|
- #010+
|
|
|
- 'Const'#010+
|
|
|
- ' // Aliases'#010+
|
|
|
- ' Amd64 = X86_64;'#010+
|
|
|
- ' PPC = PowerPC;'#010+
|
|
|
- ' PPC64 = PowerPC64;'#010+
|
|
|
- ' DOS = Go32v2;'#010+
|
|
|
- ' MacOSX = Darwin;'#010+
|
|
|
- #010+
|
|
|
- ' AllOSes = [Low(TOS)..High(TOS)];'#010+
|
|
|
- ' AllCPUs =',' [Low(TCPU)..High(TCPU)];'#010+
|
|
|
+ 'able);'#013#010+
|
|
|
+ #013#010+
|
|
|
+ 'Const'#013#010+
|
|
|
+ ' // Aliases'#013#010+
|
|
|
+ ' Amd64 =',' X86_64;'#013#010+
|
|
|
+ ' PPC = PowerPC;'#013#010+
|
|
|
+ ' PPC64 = PowerPC64;'#013#010+
|
|
|
+ ' DOS = Go32v2;'#013#010+
|
|
|
+ ' MacOSX = Darwin;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ ' AllOSes = [Low(TOS)..High(TOS)];'#013#010+
|
|
|
+ ' AllCPUs = [Low(TCPU)..High(TCPU)];'#013#010+
|
|
|
' AllUnixOSes = [Linux,FreeBSD,NetBSD,OpenBSD,Darwin,QNX,BeOS,Solaris'+
|
|
|
- ',Haiku,iphonesim,aix,Android];'#010+
|
|
|
- ' AllBSDOSes = [FreeBSD,NetBSD,OpenBSD,Darwin,iphonesim];'#010+
|
|
|
- ' AllWindowsOSes = [Win32,Win64,WinCE];'#010+
|
|
|
- ' AllLimi','t83fsOses= [go32v2,os2,emx,watcom];'#010+
|
|
|
- #010+
|
|
|
- ' AllSmartLinkLibraryOSes = [Linux]; // OSes that use .a library files'+
|
|
|
- ' for smart-linking'#010+
|
|
|
+ ',Haiku,','iphonesim,aix,Android];'#013#010+
|
|
|
+ ' AllBSDOSes = [FreeBSD,NetBSD,OpenBSD,Darwin,iphonesim];'#013#010+
|
|
|
+ ' AllWindowsOSes = [Win32,Win64,WinCE];'#013#010+
|
|
|
+ ' AllLimit83fsOses= [go32v2,os2,emx,watcom];'#013#010+
|
|
|
+ #013#010+
|
|
|
+ ' AllSmartLinkLibraryOSes = [Linux]; // OSes that use .a libr','ary fil'+
|
|
|
+ 'es for smart-linking'#013#010+
|
|
|
' AllImportLibraryOSes = AllWindowsOSes + [os2,emx,netwlibc,netware,wa'+
|
|
|
- 'tcom,go32v2,macos,nativent];'#010+
|
|
|
- #010+
|
|
|
- ' { This table',' is kept OS,Cpu because it is easier to maintain (PFV)'+
|
|
|
- ' }'#010+
|
|
|
- ' OSCPUSupported : array[TOS,TCpu] of boolean = ('#010+
|
|
|
+ 'tcom,go32v2,macos,nativent];'#013#010+
|
|
|
+ #013#010+
|
|
|
+ ' { This table is kept OS,Cpu because it is easier to maintain (PFV) }'+
|
|
|
+ #013#010+
|
|
|
+ ' OSCPUSupported : array[TOS,TCpu] of',' boolean = ('#013#010+
|
|
|
' { os none i386 m68k ppc sparc x86_64 arm ppc'+
|
|
|
- '64 avr armeb mips mipsel jvm}'#010+
|
|
|
- ' { none } ( false, f','alse, false, false, false, false, false, f'+
|
|
|
- 'alse, false, false, false, false, false),'#010+
|
|
|
- ' { linux } ( false, true, true, true, true, true, true, tru'+
|
|
|
- 'e, false, true , true , true , false),'#010+
|
|
|
- ' { go32v2 } ( false, true, false, false, ','false, false, false, f'+
|
|
|
- 'alse, false, false, false, false, false),'#010+
|
|
|
- ' { win32 } ( false, true, false, false, false, false, false, fal'+
|
|
|
- 'se, false, false, false, false, false),'#010+
|
|
|
- ' { os2 } ( false, true, false, false, false, false, false,',' f'+
|
|
|
- 'alse, false, false, false, false, false),'#010+
|
|
|
- ' { freebsd } ( false, true, true, false, false, true, false, fal'+
|
|
|
- 'se, false, false, false, false, false),'#010+
|
|
|
+ '64 avr armeb mips mipsel jvm}'#013#010+
|
|
|
+ ' { none } ( false, false, false, false, false, false, false, fal'+
|
|
|
+ 'se, false, false, false, false, false),'#013#010+
|
|
|
+ ' { l','inux } ( false, true, true, true, true, true, true, t'+
|
|
|
+ 'rue, false, true , true , true , false),'#013#010+
|
|
|
+ ' { go32v2 } ( false, true, false, false, false, false, false, fal'+
|
|
|
+ 'se, false, false, false, false, false),'#013#010+
|
|
|
+ ' { win32 } ( false, ','true, false, false, false, false, false, f'+
|
|
|
+ 'alse, false, false, false, false, false),'#013#010+
|
|
|
+ ' { os2 } ( false, true, false, false, false, false, false, fal'+
|
|
|
+ 'se, false, false, false, false, false),'#013#010+
|
|
|
+ ' { freebsd } ( false, true, true, fals','e, false, true, false, f'+
|
|
|
+ 'alse, false, false, false, false, false),'#013#010+
|
|
|
' { beos } ( false, true, false, false, false, false, false, fal'+
|
|
|
- 'se, false, false',', false, false, false),'#010+
|
|
|
- ' { netbsd } ( false, true, true, true, true, false, false, fal'+
|
|
|
- 'se, false, false, false, false, false),'#010+
|
|
|
+ 'se, false, false, false, false, false),'#013#010+
|
|
|
+ ' { netbsd } ( false, true, true, true, true, false, f','alse, f'+
|
|
|
+ 'alse, false, false, false, false, false),'#013#010+
|
|
|
' { amiga } ( false, false, true, true, false, false, false, fal'+
|
|
|
- 'se, false, false, false, false, fals','e),'#010+
|
|
|
+ 'se, false, false, false, false, false),'#013#010+
|
|
|
' { atari } ( false, false, true, false, false, false, false, fal'+
|
|
|
- 'se, false, false, false, false, false),'#010+
|
|
|
+ 'se, false',', false, false, false, false),'#013#010+
|
|
|
' { solaris } ( false, true, false, false, true, false, false, fal'+
|
|
|
- 'se, false, false, false, false, false),'#010+
|
|
|
- ' { qnx } ','( false, true, false, false, false, false, false, f'+
|
|
|
- 'alse, false, false, false, false, false),'#010+
|
|
|
+ 'se, false, false, false, false, false),'#013#010+
|
|
|
+ ' { qnx } ( false, true, false, false, false, false, false, fal'+
|
|
|
+ 'se, false, false, false, fa','lse, false),'#013#010+
|
|
|
' { netware } ( false, true, false, false, false, false, false, fal'+
|
|
|
- 'se, false, false, false, false, false),'#010+
|
|
|
- ' { openbsd } ( false, true, true',', false, false, false, false, f'+
|
|
|
- 'alse, false, false, false, false, false),'#010+
|
|
|
- ' { wdosx } ( false, true, false, false, false, false, false, fal'+
|
|
|
- 'se, false, false, false, false, false),'#010+
|
|
|
- ' { palmos } ( false, false, true, false, false, fal','se, true, f'+
|
|
|
- 'alse, false, false, false, false, false),'#010+
|
|
|
- ' { macos } ( false, false, false, true, false, false, false, fal'+
|
|
|
- 'se, false, false, false, false, false),'#010+
|
|
|
+ 'se, false, false, false, false, false),'#013#010+
|
|
|
+ ' { openbsd } ( false, true, true, false, false, false, false, fal'+
|
|
|
+ 'se, false, false, false, false, false),'#013#010+
|
|
|
+ ' ','{ wdosx } ( false, true, false, false, false, false, false, f'+
|
|
|
+ 'alse, false, false, false, false, false),'#013#010+
|
|
|
+ ' { palmos } ( false, false, true, false, false, false, true, fal'+
|
|
|
+ 'se, false, false, false, false, false),'#013#010+
|
|
|
+ ' { macos } ( fals','e, false, false, true, false, false, false, f'+
|
|
|
+ 'alse, false, false, false, false, false),'#013#010+
|
|
|
' { darwin } ( false, true, false, true, false, true, true, tru'+
|
|
|
- 'e, fa','lse, false, false, false, false),'#010+
|
|
|
- ' { emx } ( false, true, false, false, false, false, false, fal'+
|
|
|
- 'se, false, false, false, false, false),'#010+
|
|
|
+ 'e, false, false, false, false, false),'#013#010+
|
|
|
+ ' { emx } ( false, true, false, f','alse, false, false, false, f'+
|
|
|
+ 'alse, false, false, false, false, false),'#013#010+
|
|
|
' { watcom } ( false, true, false, false, false ,false, false, fal'+
|
|
|
- 'se, false, false, false, f','alse, false),'#010+
|
|
|
- ' { morphos } ( false, false, false, true, false ,false, false, fal'+
|
|
|
- 'se, false, false, false, false, false),'#010+
|
|
|
+ 'se, false, false, false, false, false),'#013#010+
|
|
|
+ ' { morphos } ( false, false, false, true, false ,false',', false, f'+
|
|
|
+ 'alse, false, false, false, false, false),'#013#010+
|
|
|
' { netwlibc }( false, true, false, false, false, false, false, fal'+
|
|
|
- 'se, false, false, false, false, false),'#010+
|
|
|
- ' { ','win64 } ( false, false, false, false, false, true, false, f'+
|
|
|
- 'alse, false, false, false, false, false),'#010+
|
|
|
+ 'se, false, false, false, false, false),'#013#010+
|
|
|
+ ' { win64 } ( false, false, false, false, false, true, false, fal'+
|
|
|
+ 'se, fa','lse, false, false, false, false),'#013#010+
|
|
|
' { wince }( false, true, false, false, false, false, true, fal'+
|
|
|
- 'se, false, false, false, false, false),'#010+
|
|
|
- ' { gba } ( false, f','alse, false, false, false, false, true, f'+
|
|
|
- 'alse, false, false, false, false, false),'#010+
|
|
|
+ 'se, false, false, false, false, false),'#013#010+
|
|
|
+ ' { gba } ( false, false, false, false, false, false, true, fal'+
|
|
|
+ 'se, false, false, false,',' false, false),'#013#010+
|
|
|
' { nds } ( false, false, false, false, false, false, true, fal'+
|
|
|
- 'se, false, false, false, false, false),'#010+
|
|
|
- ' { embedded }( false, true, true, true, ','true, true, true, t'+
|
|
|
- 'rue, true, true , false, false, false),'#010+
|
|
|
- ' { symbian } ( false, true, false, false, false, false, true, fal'+
|
|
|
- 'se, false, false, false, false, false),'#010+
|
|
|
- ' { haiku } ( false, true, false, false, false, false, false,',' f'+
|
|
|
- 'alse, false, false, false, false, false),'#010+
|
|
|
- ' { iphonesim}( false, true, false, false, false, false, false, fal'+
|
|
|
- 'se, false, false, false, false, false),'#010+
|
|
|
+ 'se, false, false, false, false, false),'#013#010+
|
|
|
+ ' { embedded }( false, true, true, true, true, true, true, tru'+
|
|
|
+ 'e, true, true , false, false, false),'#013#010+
|
|
|
+ ' ',' { symbian } ( false, true, false, false, false, false, true, f'+
|
|
|
+ 'alse, false, false, false, false, false),'#013#010+
|
|
|
+ ' { haiku } ( false, true, false, false, false, false, false, fal'+
|
|
|
+ 'se, false, false, false, false, false),'#013#010+
|
|
|
+ ' { iphonesim}( f','alse, true, false, false, false, false, false, f'+
|
|
|
+ 'alse, false, false, false, false, false),'#013#010+
|
|
|
' { aix } ( false, false, false, true, false, false, false, tru'+
|
|
|
- 'e, false, false',', false, false, false),'#010+
|
|
|
- ' { java } ( false, false, false, false, false, false, false, fal'+
|
|
|
- 'se, false, false, false, false, true ),'#010+
|
|
|
+ 'e, false, false, false, false, false),'#013#010+
|
|
|
+ ' { java } ( false, false, false',', false, false, false, false, f'+
|
|
|
+ 'alse, false, false, false, false, true ),'#013#010+
|
|
|
' { android } ( false, true, false, false, false, false, true, fal'+
|
|
|
- 'se, false, false, false, false, true',' ),'#010+
|
|
|
- ' { nativent }( false, true, false, false, false, false, false, fal'+
|
|
|
- 'se, false, false, false, false, false)'#010+
|
|
|
- ' );'#010+
|
|
|
- #010+
|
|
|
- ' // Useful'#010+
|
|
|
- ' UnitExt = '#039'.ppu'#039';'#010+
|
|
|
- ' PPUExt = UnitExt;'#010+
|
|
|
- ' PasExt = '#039'.pas'#039';'#010+
|
|
|
- ' PPExt = '#039'.pp'#039';'#010+
|
|
|
- ' IncExt = '#039'.inc'#039';'#010+
|
|
|
- ' ObjExt ',' = '#039'.o'#039';'#010+
|
|
|
- ' RstExt = '#039'.rst'#039';'#010+
|
|
|
- ' LibExt = '#039'.a'#039';'#010+
|
|
|
- ' SharedLibExt = '#039'.so'#039';'#010+
|
|
|
- ' DLLExt = '#039'.dll'#039';'#010+
|
|
|
- ' ExeExt = '#039'.exe'#039';'#010+
|
|
|
- ' DbgExt = '#039'.dbg'#039';'#010+
|
|
|
- ' ZipExt = '#039'.zip'#039';'#010+
|
|
|
- #010+
|
|
|
- ' FPMakePPFile = '#039'fpmake.pp'#039';'#010+
|
|
|
- ' ManifestFile = '#039'manifest.xml'#039';'#010+
|
|
|
- ' UnitConfigFile = '#039'fpuni','ts.cfg'#039';'#010+
|
|
|
- #010+
|
|
|
- ' DirNotFound = '#039'<dirnotfound>'#039';'#010+
|
|
|
- #010+
|
|
|
+ 'se, false, false, false, false, true ),'#013#010+
|
|
|
+ ' { nativent }( false, true, false, false, false, fa','lse, false, f'+
|
|
|
+ 'alse, false, false, false, false, false)'#013#010+
|
|
|
+ ' );'#013#010+
|
|
|
+ #013#010+
|
|
|
+ ' // Useful'#013#010+
|
|
|
+ ' UnitExt = '#039'.ppu'#039';'#013#010+
|
|
|
+ ' PPUExt = UnitExt;'#013#010+
|
|
|
+ ' PasExt = '#039'.pas'#039';'#013#010+
|
|
|
+ ' PPExt = '#039'.pp'#039';'#013#010+
|
|
|
+ ' IncExt = '#039'.inc'#039';'#013#010+
|
|
|
+ ' ObjExt = '#039'.o'#039';'#013#010+
|
|
|
+ ' RstExt = '#039'.rst'#039';'#013#010+
|
|
|
+ ' LibExt = '#039'.a'#039';'#013#010,
|
|
|
+ ' SharedLibExt = '#039'.so'#039';'#013#010+
|
|
|
+ ' DLLExt = '#039'.dll'#039';'#013#010+
|
|
|
+ ' ExeExt = '#039'.exe'#039';'#013#010+
|
|
|
+ ' DbgExt = '#039'.dbg'#039';'#013#010+
|
|
|
+ ' ZipExt = '#039'.zip'#039';'#013#010+
|
|
|
+ #013#010+
|
|
|
+ ' FPMakePPFile = '#039'fpmake.pp'#039';'#013#010+
|
|
|
+ ' ManifestFile = '#039'manifest.xml'#039';'#013#010+
|
|
|
+ ' UnitConfigFile = '#039'fpunits.cfg'#039';'#013#010+
|
|
|
+ #013#010+
|
|
|
+ ' DirNotFound = '#039'<dirnotfou','nd>'#039';'#013#010+
|
|
|
+ #013#010+
|
|
|
' UnitTargets = [ttUnit,ttImplicitUnit,ttCleanOnlyUnit,ttExampleUnit];'+
|
|
|
- #010+
|
|
|
- ' ProgramTargets = [ttProgram,ttExampleProgram];'#010+
|
|
|
- #010+
|
|
|
- ' DefaultMessages = [vlError,vlWarning,vlCommand];'#010+
|
|
|
- ' AllMessages = [vlError',',vlWarning,vlCommand,vlInfo];'#010+
|
|
|
- #010+
|
|
|
- 'Type'#010+
|
|
|
- ' TTargets = Class;'#010+
|
|
|
- ' { TNamedItem }'#010+
|
|
|
- #010+
|
|
|
- ' TNamedItem = Class(TCollectionItem)'#010+
|
|
|
- ' private'#010+
|
|
|
- ' FName: String;'#010+
|
|
|
- ' procedure SetName(const AValue: String);virtual;'#010+
|
|
|
- ' Public'#010+
|
|
|
- ' property Name : String Read FName',' Write SetName;'#010+
|
|
|
- ' end;'#010+
|
|
|
- #010+
|
|
|
- ' { TNamedCollection }'#010+
|
|
|
- #010+
|
|
|
- ' TNamedCollection = Class(TCollection)'#010+
|
|
|
- ' private'#010+
|
|
|
- ' FUniqueNames: Boolean;'#010+
|
|
|
- ' private'#010+
|
|
|
- ' function GetItem(Index: Integer): TNamedItem;'#010+
|
|
|
- ' procedure SetItem(Index: Integer; AValue: TNamedIte','m);'#010+
|
|
|
- ' Public'#010+
|
|
|
- ' Function IndexOfName(const AName : String) : Integer;'#010+
|
|
|
- ' Function ItemByName(const AName : String) : TNamedItem;'#010+
|
|
|
- ' Property UniqueNames : Boolean Read FUniqueNames;'#010+
|
|
|
- ' property Items[Index: Integer]: TNamedItem read Get','Item write Se'+
|
|
|
- 'tItem;'#010+
|
|
|
- ' end;'#010+
|
|
|
- #010+
|
|
|
- ' { TNamedItemList }'#010+
|
|
|
- #010+
|
|
|
- ' TNamedItemList = Class(TFPList)'#010+
|
|
|
- ' private'#010+
|
|
|
- ' function GetNamedItem(Index : Integer): TNamedItem;'#010+
|
|
|
+ #013#010+
|
|
|
+ ' ProgramTargets = [ttProgram,ttExampleProgram];'#013#010+
|
|
|
+ #013#010+
|
|
|
+ ' DefaultMessages = [vlError,vlWarning,vlCommand];'#013#010+
|
|
|
+ ' AllMessages = [vlError,vlWarning,vlCommand,vlInfo];'#013#010,
|
|
|
+ #013#010+
|
|
|
+ 'Type'#013#010+
|
|
|
+ ' TTargets = Class;'#013#010+
|
|
|
+ ' { TNamedItem }'#013#010+
|
|
|
+ #013#010+
|
|
|
+ ' TNamedItem = Class(TCollectionItem)'#013#010+
|
|
|
+ ' private'#013#010+
|
|
|
+ ' FName: String;'#013#010+
|
|
|
+ ' procedure SetName(const AValue: String);virtual;'#013#010+
|
|
|
+ ' Public'#013#010+
|
|
|
+ ' property Name : String Read FName Write SetName;'#013#010+
|
|
|
+ ' e','nd;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ ' { TNamedCollection }'#013#010+
|
|
|
+ #013#010+
|
|
|
+ ' TNamedCollection = Class(TCollection)'#013#010+
|
|
|
+ ' private'#013#010+
|
|
|
+ ' FUniqueNames: Boolean;'#013#010+
|
|
|
+ ' private'#013#010+
|
|
|
+ ' function GetItem(Index: Integer): TNamedItem;'#013#010+
|
|
|
+ ' procedure SetItem(Index: Integer; AValue: TNamedItem);'#013#010+
|
|
|
+ ' Pub','lic'#013#010+
|
|
|
+ ' Function IndexOfName(const AName : String) : Integer;'#013#010+
|
|
|
+ ' Function ItemByName(const AName : String) : TNamedItem;'#013#010+
|
|
|
+ ' Property UniqueNames : Boolean Read FUniqueNames;'#013#010+
|
|
|
+ ' property Items[Index: Integer]: TNamedItem read GetItem ','write Se'+
|
|
|
+ 'tItem;'#013#010+
|
|
|
+ ' end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ ' { TNamedItemList }'#013#010+
|
|
|
+ #013#010+
|
|
|
+ ' TNamedItemList = Class(TFPList)'#013#010+
|
|
|
+ ' private'#013#010+
|
|
|
+ ' function GetNamedItem(Index : Integer): TNamedItem;'#013#010+
|
|
|
' procedure SetNamedItem(Index : Integer; const AValue: TNamedItem);'+
|
|
|
- #010+
|
|
|
- ' public'#010+
|
|
|
- ' Functi','on IndexOfName(const AName : String) : Integer;'#010+
|
|
|
- ' Function ItemByName(const ANAme : String) : TNamedItem;'#010+
|
|
|
+ #013#010+
|
|
|
+ ' public'#013#010+
|
|
|
+ ' F','unction IndexOfName(const AName : String) : Integer;'#013#010+
|
|
|
+ ' Function ItemByName(const ANAme : String) : TNamedItem;'#013#010+
|
|
|
' Property NamedItems[Index : Integer] : TNamedItem Read GetNamedIte'+
|
|
|
- 'm Write SetNamedItem; default;'#010+
|
|
|
- ' end;'#010+
|
|
|
- #010+
|
|
|
- ' { TCommand }'#010+
|
|
|
- ' TComma','nd = Class(TNamedItem)'#010+
|
|
|
- ' private'#010+
|
|
|
- ' FAfterCommand: TNotifyEvent;'#010+
|
|
|
- ' FBeforeCommand: TNotifyEvent;'#010+
|
|
|
- ' FCommand: String;'#010+
|
|
|
- ' FCommandAt: TCommandAt;'#010+
|
|
|
- ' FDestFile: String;'#010+
|
|
|
- ' FIgnoreResult: Boolean;'#010+
|
|
|
- ' FOptions: TStrings;'#010+
|
|
|
- ' FSourceFile',': String;'#010+
|
|
|
- ' Function GetOptions : TStrings;'#010+
|
|
|
- ' Procedure SetOptions(Const Value : TStrings);'#010+
|
|
|
- ' Public'#010+
|
|
|
- ' Destructor Destroy; override;'#010+
|
|
|
- ' Function HaveOptions : Boolean;'#010+
|
|
|
- ' Function CmdLineOptions : String;'#010+
|
|
|
- ' Procedure ParseOptions(','S : String);'#010+
|
|
|
- ' Property SourceFile : String Read FSourceFile Write FSourceFile;'#010+
|
|
|
- ' Property DestFile : String Read FDestFile Write FDestFile;'#010+
|
|
|
- ' Property Command : String Read FCommand Write FCommand;'#010+
|
|
|
- ' Property Options : TStrings Rea','d GetOptions Write SetOptions;'#010+
|
|
|
- ' Property At : TCommandAt Read FCommandAt Write FCommandAt;'#010+
|
|
|
+ 'm Write SetNamedItem; default;'#013#010+
|
|
|
+ ' end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ ' { TCommand ','}'#013#010+
|
|
|
+ ' TCommand = Class(TNamedItem)'#013#010+
|
|
|
+ ' private'#013#010+
|
|
|
+ ' FAfterCommand: TNotifyEvent;'#013#010+
|
|
|
+ ' FBeforeCommand: TNotifyEvent;'#013#010+
|
|
|
+ ' FCommand: String;'#013#010+
|
|
|
+ ' FCommandAt: TCommandAt;'#013#010+
|
|
|
+ ' FDestFile: String;'#013#010+
|
|
|
+ ' FIgnoreResult: Boolean;'#013#010+
|
|
|
+ ' FOptions: TStrin','gs;'#013#010+
|
|
|
+ ' FSourceFile: String;'#013#010+
|
|
|
+ ' Function GetOptions : TStrings;'#013#010+
|
|
|
+ ' Procedure SetOptions(Const Value : TStrings);'#013#010+
|
|
|
+ ' Public'#013#010+
|
|
|
+ ' Destructor Destroy; override;'#013#010+
|
|
|
+ ' Function HaveOptions : Boolean;'#013#010+
|
|
|
+ ' Function CmdLineOptions : String;'#013#010,
|
|
|
+ ' Procedure ParseOptions(S : String);'#013#010+
|
|
|
+ ' Property SourceFile : String Read FSourceFile Write FSourceFile;'#013+
|
|
|
+ #010+
|
|
|
+ ' Property DestFile : String Read FDestFile Write FDestFile;'#013#010+
|
|
|
+ ' Property Command : String Read FCommand Write FCommand;'#013#010+
|
|
|
+ ' ','Property Options : TStrings Read GetOptions Write SetOptions;'#013+
|
|
|
+ #010+
|
|
|
+ ' Property At : TCommandAt Read FCommandAt Write FCommandAt;'#013#010+
|
|
|
' Property IgnoreResult : Boolean Read FIgnoreResult Write FIgnoreRe'+
|
|
|
- 'sult;'#010+
|
|
|
- ' Property BeforeCommand : TNotifyEvent Read FBeforeCommand Write FB',
|
|
|
- 'eforeCommand;'#010+
|
|
|
+ 'sult;'#013#010+
|
|
|
+ ' Property BeforeCommand : TNotify','Event Read FBeforeCommand Write '+
|
|
|
+ 'FBeforeCommand;'#013#010+
|
|
|
' Property AfterCommand : TNotifyEvent Read FAfterCommand Write FAft'+
|
|
|
- 'erCommand;'#010+
|
|
|
- ' end;'#010+
|
|
|
- #010+
|
|
|
- ' { TCommands }'#010+
|
|
|
- #010+
|
|
|
- ' TCommands = Class(TNamedCollection)'#010+
|
|
|
- ' private'#010+
|
|
|
- ' FDefaultAt: TCommandAt;'#010+
|
|
|
- ' function GetCommand(const Dest : String)',': TCommand;'#010+
|
|
|
- ' function GetCommandItem(Index : Integer): TCommand;'#010+
|
|
|
+ 'erCommand;'#013#010+
|
|
|
+ ' end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ ' { TCommands }'#013#010+
|
|
|
+ #013#010+
|
|
|
+ ' TCommands = Class(TNamedCollection)'#013#010+
|
|
|
+ ' private'#013#010+
|
|
|
+ ' FDefaultAt: TCommandAt;'#013#010+
|
|
|
+ ' ',' function GetCommand(const Dest : String): TCommand;'#013#010+
|
|
|
+ ' function GetCommandItem(Index : Integer): TCommand;'#013#010+
|
|
|
' procedure SetCommandItem(Index : Integer; const AValue: TCommand);'+
|
|
|
- #010+
|
|
|
- ' Public'#010+
|
|
|
- ' Function AddCommand(Const Cmd : String) : TCommand;'#010+
|
|
|
- ' Function AddCommand(Const Cmd,Op','tions : String) : TCommand;'#010+
|
|
|
+ #013#010+
|
|
|
+ ' Public'#013#010+
|
|
|
+ ' Function AddCommand(Const Cmd : String) :',' TCommand;'#013#010+
|
|
|
+ ' Function AddCommand(Const Cmd,Options : String) : TCommand;'#013#010+
|
|
|
' Function AddCommand(Const Cmd,Options,Dest,Source : String) : TCom'+
|
|
|
- 'mand;'#010+
|
|
|
+ 'mand;'#013#010+
|
|
|
' Function AddCommand(At : TCommandAt; Const Cmd : String) : TComman'+
|
|
|
- 'd;'#010+
|
|
|
- ' Function AddCommand(At : TCommandAt; Const Cmd,Options : St','ring)'+
|
|
|
- ' : TCommand;'#010+
|
|
|
+ 'd;'#013#010+
|
|
|
+ ' Function',' AddCommand(At : TCommandAt; Const Cmd,Options : String)'+
|
|
|
+ ' : TCommand;'#013#010+
|
|
|
' Function AddCommand(At : TCommandAt; Const Cmd,Options, Dest,Sourc'+
|
|
|
- 'e : String) : TCommand;'#010+
|
|
|
+ 'e : String) : TCommand;'#013#010+
|
|
|
' Property CommandItems[Index : Integer] : TCommand Read GetCommandI'+
|
|
|
- 'tem Write SetCommandItem;'#010+
|
|
|
- ' Property Commands[Dest : Str','ing] : TCommand Read GetCommand; def'+
|
|
|
- 'ault;'#010+
|
|
|
- ' Property DefaultAt : TCommandAt Read FDefaultAt Write FDefaultAt;'#010+
|
|
|
- ' end;'#010+
|
|
|
- #010+
|
|
|
- ' { TFPVersion }'#010+
|
|
|
- #010+
|
|
|
- ' TFPVersion = Class(TPersistent)'#010+
|
|
|
- ' private'#010+
|
|
|
- ' FMajor,'#010+
|
|
|
- ' FMinor,'#010+
|
|
|
- ' FMicro,'#010+
|
|
|
- ' FBuild : Intege','r;'#010+
|
|
|
- ' function GetAsString: String;'#010+
|
|
|
- ' function GetEmpty: Boolean;'#010+
|
|
|
- ' procedure SetAsString(const AValue: String);'#010+
|
|
|
- ' Public'#010+
|
|
|
- ' Procedure Clear;'#010+
|
|
|
- ' Procedure Assign(Source : TPersistent); override;'#010+
|
|
|
- ' Function CompareVersion(AVersion : TF','PVersion) : Integer;'#010+
|
|
|
- ' Function SameVersion(AVersion : TFPVersion) : Boolean;'#010+
|
|
|
- ' Property AsString : String Read GetAsString Write SetAsString;'#010+
|
|
|
- ' Property Empty : Boolean Read GetEmpty;'#010+
|
|
|
- ' Published'#010+
|
|
|
- ' Property Major : Integer Read FMajor ','Write FMajor;'#010+
|
|
|
- ' Property Minor : Integer Read FMinor Write FMinor;'#010+
|
|
|
- ' Property Micro : Integer Read FMicro Write FMicro;'#010+
|
|
|
- ' Property Build : Integer Read FBuild Write FBuild;'#010+
|
|
|
- ' end;'#010+
|
|
|
- #010+
|
|
|
- ' { TConditionalString }'#010+
|
|
|
- ' TConditionalString = Class'#010+
|
|
|
- ' ','private'#010+
|
|
|
- ' FOSes : TOSes;'#010+
|
|
|
- ' FCPUs : TCPUs;'#010+
|
|
|
- ' FValue : String;'#010+
|
|
|
- ' Public'#010+
|
|
|
- ' Constructor Create;virtual;'#010+
|
|
|
- ' Property Value : String Read FValue Write FValue;'#010+
|
|
|
- ' Property OSes : TOSes Read FOSes Write FOSes;'#010+
|
|
|
- ' Property CPUs : TC','PUs Read FCPUS Write FCPUs;'#010+
|
|
|
- ' end;'#010+
|
|
|
- #010+
|
|
|
- ' TConditionalStringClass = class of TConditionalString;'#010+
|
|
|
- #010+
|
|
|
- ' { TConditionalStrings }'#010+
|
|
|
- #010+
|
|
|
- ' TConditionalStrings = Class(TFPList)'#010+
|
|
|
- ' private'#010+
|
|
|
- ' FCSClass : TConditionalStringClass;'#010+
|
|
|
- ' function GetConditionalStr','ing(Index : Integer): TConditionalStri'+
|
|
|
- 'ng;'#010+
|
|
|
+ 'tem W','rite SetCommandItem;'#013#010+
|
|
|
+ ' Property Commands[Dest : String] : TCommand Read GetCommand; defau'+
|
|
|
+ 'lt;'#013#010+
|
|
|
+ ' Property DefaultAt : TCommandAt Read FDefaultAt Write FDefaultAt;'#013+
|
|
|
+ #010+
|
|
|
+ ' end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ ' { TFPVersion }'#013#010+
|
|
|
+ #013#010+
|
|
|
+ ' TFPVersion = Class(TPersistent)'#013#010+
|
|
|
+ ' priva','te'#013#010+
|
|
|
+ ' FMajor,'#013#010+
|
|
|
+ ' FMinor,'#013#010+
|
|
|
+ ' FMicro,'#013#010+
|
|
|
+ ' FBuild : Integer;'#013#010+
|
|
|
+ ' function GetAsString: String;'#013#010+
|
|
|
+ ' function GetEmpty: Boolean;'#013#010+
|
|
|
+ ' procedure SetAsString(const AValue: String);'#013#010+
|
|
|
+ ' Public'#013#010+
|
|
|
+ ' Procedure Clear;'#013#010+
|
|
|
+ ' Procedure Assign(So','urce : TPersistent); override;'#013#010+
|
|
|
+ ' Function CompareVersion(AVersion : TFPVersion) : Integer;'#013#010+
|
|
|
+ ' Function SameVersion(AVersion : TFPVersion) : Boolean;'#013#010+
|
|
|
+ ' Property AsString : String Read GetAsString Write SetAsString;'#013#010+
|
|
|
+ ' Property Empty : ','Boolean Read GetEmpty;'#013#010+
|
|
|
+ ' Published'#013#010+
|
|
|
+ ' Property Major : Integer Read FMajor Write FMajor;'#013#010+
|
|
|
+ ' Property Minor : Integer Read FMinor Write FMinor;'#013#010+
|
|
|
+ ' Property Micro : Integer Read FMicro Write FMicro;'#013#010+
|
|
|
+ ' Property Build : Integer Read FBuil','d Write FBuild;'#013#010+
|
|
|
+ ' end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ ' { TConditionalString }'#013#010+
|
|
|
+ ' TConditionalString = Class'#013#010+
|
|
|
+ ' private'#013#010+
|
|
|
+ ' FOSes : TOSes;'#013#010+
|
|
|
+ ' FCPUs : TCPUs;'#013#010+
|
|
|
+ ' FValue : String;'#013#010+
|
|
|
+ ' Public'#013#010+
|
|
|
+ ' Constructor Create;virtual;'#013#010+
|
|
|
+ ' Property Value : String Read FVa','lue Write FValue;'#013#010+
|
|
|
+ ' Property OSes : TOSes Read FOSes Write FOSes;'#013#010+
|
|
|
+ ' Property CPUs : TCPUs Read FCPUS Write FCPUs;'#013#010+
|
|
|
+ ' end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ ' TConditionalStringClass = class of TConditionalString;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ ' { TConditionalStrings }'#013#010+
|
|
|
+ #013#010+
|
|
|
+ ' TConditionalStrin','gs = Class(TFPList)'#013#010+
|
|
|
+ ' private'#013#010+
|
|
|
+ ' FCSClass : TConditionalStringClass;'#013#010+
|
|
|
+ ' function GetConditionalString(Index : Integer): TConditionalString'+
|
|
|
+ ';'#013#010+
|
|
|
' procedure SetConditionalString(Index : Integer; const AValue: TCon'+
|
|
|
- 'ditionalString);'#010+
|
|
|
- ' Public'#010+
|
|
|
- ' Constructor Create(AClass:TConditionalStringClass);'#010+
|
|
|
- ' Function Add(Const Value : String) : TCond','itionalString;inline;'#010+
|
|
|
+ 'ditionalString);'#013#010+
|
|
|
+ ' Publ','ic'#013#010+
|
|
|
+ ' Constructor Create(AClass:TConditionalStringClass);'#013#010+
|
|
|
+ ' Function Add(Const Value : String) : TConditionalString;inline;'#013+
|
|
|
+ #010+
|
|
|
' Function Add(Const Value : String;const OSes:TOSes) : TConditional'+
|
|
|
- 'String;inline;'#010+
|
|
|
- '{$ifdef cpu_only_overloads}'#010+
|
|
|
+ 'String;inline;'#013#010+
|
|
|
+ '{$ifdef cpu_only_overloa','ds}'#013#010+
|
|
|
' Function Add(Const Value : String;const CPUs:TCPUs) : TConditional'+
|
|
|
- 'String;inline;'#010+
|
|
|
- '{$endif cpu_only_ove','rloads}'#010+
|
|
|
+ 'String;inline;'#013#010+
|
|
|
+ '{$endif cpu_only_overloads}'#013#010+
|
|
|
' Function Add(Const Value : String;const CPUs:TCPUs;const OSes:TOSe'+
|
|
|
- 's) : TConditionalString;'#010+
|
|
|
- ' Property ConditionalStrings[Index : Integer] : TConditionalString '+
|
|
|
- 'Read GetConditionalString Write SetConditionalString; default;'#010+
|
|
|
- ' en','d;'#010+
|
|
|
- #010+
|
|
|
- ' { TConditionalDestString }'#010+
|
|
|
- #010+
|
|
|
- ' TConditionalDestString = Class(TConditionalString)'#010+
|
|
|
- ' private'#010+
|
|
|
- ' FDestPath: string;'#010+
|
|
|
- ' public'#010+
|
|
|
- ' property DestPath: string read FDestPath write FDestPath;'#010+
|
|
|
- ' end;'#010+
|
|
|
- #010+
|
|
|
- ' TConditionalDestStringClass = class of ','TConditionalDestString;'#010+
|
|
|
- #010+
|
|
|
- ' { TConditionalDestStrings }'#010+
|
|
|
- #010+
|
|
|
- ' TConditionalDestStrings = Class(TConditionalStrings)'#010+
|
|
|
- ' private'#010+
|
|
|
+ 's) : TConditionalString;'#013#010+
|
|
|
+ ' Property Conditional','Strings[Index : Integer] : TConditionalStrin'+
|
|
|
+ 'g Read GetConditionalString Write SetConditionalString; default;'#013#010+
|
|
|
+ ' end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ ' { TConditionalDestString }'#013#010+
|
|
|
+ #013#010+
|
|
|
+ ' TConditionalDestString = Class(TConditionalString)'#013#010+
|
|
|
+ ' private'#013#010+
|
|
|
+ ' FDestPath: string;'#013,#010+
|
|
|
+ ' public'#013#010+
|
|
|
+ ' property DestPath: string read FDestPath write FDestPath;'#013#010+
|
|
|
+ ' end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ ' TConditionalDestStringClass = class of TConditionalDestString;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ ' { TConditionalDestStrings }'#013#010+
|
|
|
+ #013#010+
|
|
|
+ ' TConditionalDestStrings = Class(TConditionalStrings)'#013,#010+
|
|
|
+ ' private'#013#010+
|
|
|
' function GetConditionalString(Index : Integer): TConditionalDestSt'+
|
|
|
- 'ring;'#010+
|
|
|
- ' procedure SetConditionalString(Index : ','Integer; AValue: TConditi'+
|
|
|
- 'onalDestString);'#010+
|
|
|
- ' public'#010+
|
|
|
- ' Constructor Create(AClass:TConditionalDestStringClass);'#010+
|
|
|
+ 'ring;'#013#010+
|
|
|
+ ' procedure SetConditionalString(Index : Integer; AValue: TCondition'+
|
|
|
+ 'alDestString);'#013#010+
|
|
|
+ ' public'#013#010+
|
|
|
+ ' Constructor Create(AClass:TConditionalDestStringCla','ss);'#013#010+
|
|
|
' Function Add(Const Value : String; ADestPath: String) : TCondition'+
|
|
|
- 'alDestString;inline;'#010+
|
|
|
- ' Function Add(Const Value : String;','const OSes:TOSes; ADestPath: S'+
|
|
|
- 'tring) : TConditionalDestString;inline;'#010+
|
|
|
- '{$ifdef cpu_only_overloads}'#010+
|
|
|
- ' Function Add(Const Value : String;const CPUs:TCPUs; ADestPath: Str'+
|
|
|
- 'ing) : TConditionalDestString;inline;'#010+
|
|
|
- '{$endif cpu_only_overloads}'#010+
|
|
|
- ' Fu','nction Add(Const Value : String;const CPUs:TCPUs;const OSes:TO'+
|
|
|
- 'Ses; ADestPath: String) : TConditionalDestString;'#010+
|
|
|
+ 'alDestString;inline;'#013#010+
|
|
|
+ ' Function Add(Const Value : String;const OSes:TOSes; ADestPath: Str'+
|
|
|
+ 'ing) : TConditionalDestString;inline;'#013#010+
|
|
|
+ '{$ifdef cpu_only_overloads}'#013#010+
|
|
|
+ ' ','Function Add(Const Value : String;const CPUs:TCPUs; ADestPath: S'+
|
|
|
+ 'tring) : TConditionalDestString;inline;'#013#010+
|
|
|
+ '{$endif cpu_only_overloads}'#013#010+
|
|
|
+ ' Function Add(Const Value : String;const CPUs:TCPUs;const OSes:TOSe'+
|
|
|
+ 's; ADestPath: String) : TConditional','DestString;'#013#010+
|
|
|
' Property ConditionalStrings[Index : Integer] : TConditionalDestStr'+
|
|
|
- 'ing Read GetConditionalString Write SetConditionalString; ','default;'#010+
|
|
|
- ' end;'#010+
|
|
|
- #010+
|
|
|
- ' { TDictionary }'#010+
|
|
|
- #010+
|
|
|
- ' TReplaceFunction = Function (Const AName,Args : String) : String of '+
|
|
|
- 'Object;'#010+
|
|
|
- #010+
|
|
|
- ' TDictionary = Class(TComponent)'#010+
|
|
|
- ' private'#010+
|
|
|
- ' FList : TStringList;'#010+
|
|
|
- ' Public'#010+
|
|
|
- ' Constructor Create(AOwner : TComponent); ov','erride;'#010+
|
|
|
- ' Destructor Destroy;override;'#010+
|
|
|
- ' Procedure AddVariable(const AName,Value : String);'#010+
|
|
|
+ 'ing Read GetConditionalString Write SetConditionalString; default;'#013+
|
|
|
+ #010+
|
|
|
+ ' end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ ' { TDictionary }'#013#010+
|
|
|
+ #013#010+
|
|
|
+ ' TReplaceFunction = Function (Const AName,Args : String) ',': String o'+
|
|
|
+ 'f Object;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ ' TDictionary = Class(TComponent)'#013#010+
|
|
|
+ ' private'#013#010+
|
|
|
+ ' FList : TStringList;'#013#010+
|
|
|
+ ' Public'#013#010+
|
|
|
+ ' Constructor Create(AOwner : TComponent); override;'#013#010+
|
|
|
+ ' Destructor Destroy;override;'#013#010+
|
|
|
+ ' Procedure AddVariable(const AName,Value :',' String);'#013#010+
|
|
|
' Procedure AddFunction(const AName : String; FReplacement : TReplac'+
|
|
|
- 'eFunction);'#010+
|
|
|
- ' Procedure RemoveItem(const AName : String);'#010+
|
|
|
- ' Function G','etValue(AName : String) : String;'#010+
|
|
|
- ' Function GetValue(const AName,Args : String) : String; virtual;'#010+
|
|
|
+ 'eFunction);'#013#010+
|
|
|
+ ' Procedure RemoveItem(const AName : String);'#013#010+
|
|
|
+ ' Function GetValue(AName : String) : String;'#013#010+
|
|
|
+ ' Function GetValue(const AName,Args : String)',' : String; virtual;'#013+
|
|
|
+ #010+
|
|
|
' Function ReplaceStrings(Const ASource : String) : String; virtual;'+
|
|
|
+ #013#010+
|
|
|
+ ' Function Substitute(Const Source : String; Macros : Array of strin'+
|
|
|
+ 'g) : String; virtual;'#013#010+
|
|
|
+ ' end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ ' { TPackageDictionary }'#013#010+
|
|
|
+ #013#010+
|
|
|
+ ' TPackageDictio','nary = Class(TDictionary)'#013#010+
|
|
|
+ ' private'#013#010+
|
|
|
+ ' FMasterDictionary: TDictionary;'#013#010+
|
|
|
+ ' Public'#013#010+
|
|
|
+ ' Function GetValue(const AName,Args : String) : String; override;'#013+
|
|
|
+ #010+
|
|
|
+ ' property MasterDictionary: TDictionary read FMasterDictionary writ'+
|
|
|
+ 'e FMasterDictio','nary;'#013#010+
|
|
|
+ ' end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ #013#010+
|
|
|
+ ' { TDependency }'#013#010+
|
|
|
+ ' TDependency = Class(TConditionalString)'#013#010+
|
|
|
+ ' private'#013#010+
|
|
|
+ ' FDependencyType : TDependencyType;'#013#010+
|
|
|
+ ' // Package, Unit'#013#010+
|
|
|
+ ' FTarget : TObject;'#013#010+
|
|
|
+ ' FVersion : TFPVersion;'#013#010+
|
|
|
+ ' FRequireChecksum : Cardinal;'#013#010,
|
|
|
+ ' // Filenames, Includes'#013#010+
|
|
|
+ ' FTargetFileName : String;'#013#010+
|
|
|
+ ' Function GetVersion : string;'#013#010+
|
|
|
+ ' Procedure SetVersion(const V : string);'#013#010+
|
|
|
+ ' Public'#013#010+
|
|
|
+ ' Constructor Create;override;'#013#010+
|
|
|
+ ' Destructor Destroy;override;'#013#010+
|
|
|
+ ' Property Target : T','Object Read FTarget Write FTarget;'#013#010+
|
|
|
+ ' Property DependencyType : TDependencyType Read FDependencyType;'#013+
|
|
|
#010+
|
|
|
- ' Function Substitute(Const Source : String; Macros : Array of st','r'+
|
|
|
- 'ing) : String; virtual;'#010+
|
|
|
- ' end;'#010+
|
|
|
- #010+
|
|
|
- ' { TPackageDictionary }'#010+
|
|
|
- #010+
|
|
|
- ' TPackageDictionary = Class(TDictionary)'#010+
|
|
|
- ' private'#010+
|
|
|
- ' FMasterDictionary: TDictionary;'#010+
|
|
|
- ' Public'#010+
|
|
|
- ' Function GetValue(const AName,Args : String) : String; override;'#010+
|
|
|
- ' property Ma','sterDictionary: TDictionary read FMasterDictionary wr'+
|
|
|
- 'ite FMasterDictionary;'#010+
|
|
|
- ' end;'#010+
|
|
|
- #010+
|
|
|
- #010+
|
|
|
- ' { TDependency }'#010+
|
|
|
- ' TDependency = Class(TConditionalString)'#010+
|
|
|
- ' private'#010+
|
|
|
- ' FDependencyType : TDependencyType;'#010+
|
|
|
- ' // Package, Unit'#010+
|
|
|
- ' FTarget : TObject;'#010+
|
|
|
- ' ',' FVersion : TFPVersion;'#010+
|
|
|
- ' FRequireChecksum : Cardinal;'#010+
|
|
|
- ' // Filenames, Includes'#010+
|
|
|
- ' FTargetFileName : String;'#010+
|
|
|
- ' Function GetVersion : string;'#010+
|
|
|
- ' Procedure SetVersion(const V : string);'#010+
|
|
|
- ' Public'#010+
|
|
|
- ' Constructor Create;override;'#010+
|
|
|
- ' D','estructor Destroy;override;'#010+
|
|
|
- ' Property Target : TObject Read FTarget Write FTarget;'#010+
|
|
|
- ' Property DependencyType : TDependencyType Read FDependencyType;'#010+
|
|
|
' Property TargetFileName : String Read FTargetFileName Write FTarge'+
|
|
|
- 'tFileName;'#010+
|
|
|
- ' P','roperty Version : String Read GetVersion Write SetVersion;'#010+
|
|
|
+ 'tFileName;'#013#010+
|
|
|
+ ' Property Version : String Read GetVersion Write S','etVersion;'#013#010+
|
|
|
' Property RequireChecksum : Cardinal Read FRequireChecksum Write FR'+
|
|
|
- 'equireChecksum;'#010+
|
|
|
- ' end;'#010+
|
|
|
- #010+
|
|
|
- ' { TPackageVariant }'#010+
|
|
|
- #010+
|
|
|
- ' TPackage = Class;'#010+
|
|
|
- ' TPackageVariant = class(TNamedItem)'#010+
|
|
|
- ' priv','ate'#010+
|
|
|
- ' FOptions: TStrings;'#010+
|
|
|
- ' FTargets: TTargets;'#010+
|
|
|
- ' public'#010+
|
|
|
- ' constructor Create(ACollection: TCollection); override;'#010+
|
|
|
- ' destructor Destroy; override;'#010+
|
|
|
- ' property Options: TStrings read FOptions;'#010+
|
|
|
- ' property Targets: TTargets read FTa','rgets;'#010+
|
|
|
- ' end;'#010+
|
|
|
- #010+
|
|
|
- ' { TPackageVariants }'#010+
|
|
|
- #010+
|
|
|
- ' TPackageVariants = class(TNamedCollection)'#010+
|
|
|
- ' private'#010+
|
|
|
- ' FActivePackageVariantName: string;'#010+
|
|
|
- ' FDefaultPackageVariantName: string;'#010+
|
|
|
- ' FIsInheritable: boolean;'#010+
|
|
|
- ' FMasterPackage: TPackage;'#010+
|
|
|
- ' FNam','e: string;'#010+
|
|
|
- ' function GetActivePackageVariant: TPackageVariant;'#010+
|
|
|
- ' function GetDefaultPackageVariant: TPackageVariant;'#010+
|
|
|
- ' procedure SetActivePackageVariantName(AValue: string);'#010+
|
|
|
- ' procedure SetDefaultPackageVariantName(AValue: string);',#010+
|
|
|
- ' public'#010+
|
|
|
- ' function Add(AName: String): TPackageVariant; overload; virtual;'#010+
|
|
|
- ' property Name: string read FName write FName;'#010+
|
|
|
- ' property MasterPackage: TPackage read FMasterPackage;'#010+
|
|
|
- ' property DefaultPackageVariant: TPackageVariant r','ead GetDefaultP'+
|
|
|
- 'ackageVariant;'#010+
|
|
|
+ 'equireChecksum;'#013#010+
|
|
|
+ ' end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ ' { TPackageVariant }'#013#010+
|
|
|
+ #013#010+
|
|
|
+ ' TPackage = Class;'#013#010+
|
|
|
+ ' TPackageVariant = class(TNamedItem)'#013#010+
|
|
|
+ ' private'#013#010+
|
|
|
+ ' FOptions: TStrings;'#013#010+
|
|
|
+ ' FTarge','ts: TTargets;'#013#010+
|
|
|
+ ' public'#013#010+
|
|
|
+ ' constructor Create(ACollection: TCollection); override;'#013#010+
|
|
|
+ ' destructor Destroy; override;'#013#010+
|
|
|
+ ' property Options: TStrings read FOptions;'#013#010+
|
|
|
+ ' property Targets: TTargets read FTargets;'#013#010+
|
|
|
+ ' end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ ' { TPackageVar','iants }'#013#010+
|
|
|
+ #013#010+
|
|
|
+ ' TPackageVariants = class(TNamedCollection)'#013#010+
|
|
|
+ ' private'#013#010+
|
|
|
+ ' FActivePackageVariantName: string;'#013#010+
|
|
|
+ ' FDefaultPackageVariantName: string;'#013#010+
|
|
|
+ ' FIsInheritable: boolean;'#013#010+
|
|
|
+ ' FMasterPackage: TPackage;'#013#010+
|
|
|
+ ' FName: string;'#013#010+
|
|
|
+ ' functi','on GetActivePackageVariant: TPackageVariant;'#013#010+
|
|
|
+ ' function GetDefaultPackageVariant: TPackageVariant;'#013#010+
|
|
|
+ ' procedure SetActivePackageVariantName(AValue: string);'#013#010+
|
|
|
+ ' procedure SetDefaultPackageVariantName(AValue: string);'#013#010+
|
|
|
+ ' public'#013#010+
|
|
|
+ ' fu','nction Add(AName: String): TPackageVariant; overload; virtual;'+
|
|
|
+ #013#010+
|
|
|
+ ' property Name: string read FName write FName;'#013#010+
|
|
|
+ ' property MasterPackage: TPackage read FMasterPackage;'#013#010+
|
|
|
+ ' property DefaultPackageVariant: TPackageVariant read GetDefaul','tP'+
|
|
|
+ 'ackageVariant;'#013#010+
|
|
|
' property ActivePackageVariant: TPackageVariant read GetActivePacka'+
|
|
|
- 'geVariant;'#010+
|
|
|
+ 'geVariant;'#013#010+
|
|
|
' property DefaultPackageVariantName: string read FDefaultPackageVar'+
|
|
|
- 'iantName write SetDefaultPackageVariantName;'#010+
|
|
|
- ' property A','ctivePackageVariantName: string read FActivePackageVar'+
|
|
|
- 'iantName write SetActivePackageVariantName;'#010+
|
|
|
- ' property IsInheritable: boolean read FIsInheritable;'#010+
|
|
|
- ' end;'#010+
|
|
|
- #010+
|
|
|
- #010+
|
|
|
- ' TDependencies = Class(TConditionalStrings)'#010+
|
|
|
- ' function GetDependency(Inde','x : Integer): TDependency;'#010+
|
|
|
+ 'iantName write SetDefaultPackageVariantName;'#013#010+
|
|
|
+ ' property ActivePacka','geVariantName: string read FActivePackageVar'+
|
|
|
+ 'iantName write SetActivePackageVariantName;'#013#010+
|
|
|
+ ' property IsInheritable: boolean read FIsInheritable;'#013#010+
|
|
|
+ ' end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ #013#010+
|
|
|
+ ' TDependencies = Class(TConditionalStrings)'#013#010+
|
|
|
+ ' function GetDependency(Index : ','Integer): TDependency;'#013#010+
|
|
|
' procedure SetDependency(Index : Integer; const AValue: TDependency'+
|
|
|
- ');'#010+
|
|
|
- ' Public'#010+
|
|
|
- ' Function Add(Const Value : String) : TDependency;inline;'#010+
|
|
|
+ ');'#013#010+
|
|
|
+ ' Public'#013#010+
|
|
|
+ ' Function Add(Const Value : String) : TDependency;inline;'#013#010+
|
|
|
' Function Add(Const Value : String;const OSes:TOSes) : TDependency;',
|
|
|
- 'inline;'#010+
|
|
|
- '{$ifdef cpu_only_overloads}'#010+
|
|
|
+ 'inline;'#013#010+
|
|
|
+ '{$ifdef cpu_only_overloads}'#013#010+
|
|
|
' Function Add(Const Value : String;const CPUs:TCPUs) : TDependency;'+
|
|
|
- 'inline;'#010+
|
|
|
- '{$endif cpu_only_overloads}'#010+
|
|
|
+ 'inline;'#013#010+
|
|
|
+ '{$endif cpu_only_overloads}'#013#010+
|
|
|
' Function Add(Const Value : String;const CPUs:TCPUs;const OSes:TOSe'+
|
|
|
- 's) : TDependency;'#010+
|
|
|
- ' Functi','on AddUnit(Const Value : String) : TDependency;inline;'#010+
|
|
|
+ 's) : TDependency;'#013#010+
|
|
|
+ ' F','unction AddUnit(Const Value : String) : TDependency;inline;'#013+
|
|
|
+ #010+
|
|
|
' Function AddUnit(Const Value : String;const OSes:TOSes) : TDepende'+
|
|
|
- 'ncy;inline;'#010+
|
|
|
- '{$ifdef cpu_only_overloads}'#010+
|
|
|
- ' Function AddUnit(Const Value : String;const CPUs:TCPUs) : TDepende'+
|
|
|
- 'ncy;i','nline;'#010+
|
|
|
- '{$endif cpu_only_overloads}'#010+
|
|
|
+ 'ncy;inline;'#013#010+
|
|
|
+ '{$ifdef cpu_only_overloads}'#013#010+
|
|
|
+ ' Function AddUnit(Const Value : String;const CPUs:TCPUs) : TDepe','n'+
|
|
|
+ 'dency;inline;'#013#010+
|
|
|
+ '{$endif cpu_only_overloads}'#013#010+
|
|
|
' Function AddUnit(Const Value : String;const CPUs:TCPUs;const OSes:'+
|
|
|
- 'TOSes) : TDependency;'#010+
|
|
|
- ' Function AddInclude(Const Value : String) : TDependency;inline;'#010+
|
|
|
- ' Function AddInclude(Const Value : String;','const OSes:TOSes) : TDe'+
|
|
|
- 'pendency;inline;'#010+
|
|
|
- '{$ifdef cpu_only_overloads}'#010+
|
|
|
+ 'TOSes) : TDependency;'#013#010+
|
|
|
+ ' Function AddInclude(Const Value : String) : TDependency;inline;'#013+
|
|
|
+ #010+
|
|
|
+ ' Function AddInclude(Const Val','ue : String;const OSes:TOSes) : TDe'+
|
|
|
+ 'pendency;inline;'#013#010+
|
|
|
+ '{$ifdef cpu_only_overloads}'#013#010+
|
|
|
' Function AddInclude(Const Value : String;const CPUs:TCPUs) : TDepe'+
|
|
|
- 'ndency;inline;'#010+
|
|
|
- '{$endif cpu_only_overloads}'#010+
|
|
|
- ' Function AddInclude(Const Value : String;const CPUs:TCP','Us;const '+
|
|
|
- 'OSes:TOSes) : TDependency;'#010+
|
|
|
+ 'ndency;inline;'#013#010+
|
|
|
+ '{$endif cpu_only_overloads}'#013#010+
|
|
|
+ ' Function AddInclude(Const Value : Strin','g;const CPUs:TCPUs;const '+
|
|
|
+ 'OSes:TOSes) : TDependency;'#013#010+
|
|
|
' Property Dependencies[Index : Integer] : TDependency Read GetDepen'+
|
|
|
- 'dency Write SetDependency; default;'#010+
|
|
|
- ' end;'#010+
|
|
|
- #010+
|
|
|
- ' { TTarget }'#010+
|
|
|
- #010+
|
|
|
- ' TTarget = Class(TNamedItem)'#010+
|
|
|
- ' private'#010+
|
|
|
- ' FInstall : Boolean;'#010+
|
|
|
- ' FAfterC','lean: TNotifyEvent;'#010+
|
|
|
- ' FAfterCompile: TNotifyEvent;'#010+
|
|
|
- ' FBeforeClean: TNotifyEvent;'#010+
|
|
|
- ' FBeforeCompile: TNotifyEvent;'#010+
|
|
|
- ' FCPUs: TCPUs;'#010+
|
|
|
- ' FOSes: TOSes;'#010+
|
|
|
- ' FMode: TCompilerMode;'#010+
|
|
|
- ' FResourceStrings: Boolean;'#010+
|
|
|
- ' FObjectPath,'#010+
|
|
|
- ' FUnitPa','th,'#010+
|
|
|
- ' FIncludePath : TConditionalStrings;'#010+
|
|
|
- ' FDependencies : TDependencies;'#010+
|
|
|
- ' FCommands : TCommands;'#010+
|
|
|
- ' FDirectory: String;'#010+
|
|
|
- ' FExtension: String;'#010+
|
|
|
- ' FTargetSourceFileName : String;'#010+
|
|
|
- ' FFileType: TFileType;'#010+
|
|
|
- ' FOptions: TStrings;'#010,
|
|
|
- ' FFPCTarget: String;'#010+
|
|
|
- ' FTargetState: TTargetState;'#010+
|
|
|
- ' FTargetType: TTargetType;'#010+
|
|
|
- ' FXML: string;'#010+
|
|
|
- ' function GetOptions: TStrings;'#010+
|
|
|
- ' procedure SetOptions(const AValue: TStrings);'#010+
|
|
|
- ' Protected'#010+
|
|
|
- ' Function GetSourceFileName : String','; virtual;'#010+
|
|
|
- ' Function GetUnitFileName : String; virtual;'#010+
|
|
|
- ' function GetUnitLibFileName: String; virtual;'#010+
|
|
|
- ' Function GetObjectFileName : String; virtual;'#010+
|
|
|
- ' Function GetRSTFileName : String; Virtual;'#010+
|
|
|
- ' function GetImportLibFileName(','AOS : TOS) : String; Virtual;'#010+
|
|
|
- ' Function GetProgramFileName(AOS : TOS) : String; Virtual;'#010+
|
|
|
- ' Function GetProgramDebugFileName(AOS : TOS) : String; Virtual;'#010+
|
|
|
- ' Public'#010+
|
|
|
- ' Constructor Create(ACollection : TCollection); override;'#010+
|
|
|
- ' Destruc','tor Destroy; override;'#010+
|
|
|
- ' procedure AssignTo(Dest: TPersistent); override;'#010+
|
|
|
- ' Function GetOutputFileName (AOs : TOS) : String; Virtual;'#010+
|
|
|
- ' Function HaveOptions : Boolean;'#010+
|
|
|
- ' procedure SetName(const AValue: String);override;'#010+
|
|
|
- ' procedu','re SetXML(const AValue: string);'#010+
|
|
|
+ 'dency Write SetDependency; default;'#013#010+
|
|
|
+ ' end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ ' { TTarget }'#013#010+
|
|
|
+ #013#010+
|
|
|
+ ' TTarget = Class(TNamedItem)'#013#010+
|
|
|
+ ' private'#013#010+
|
|
|
+ ' FInstal','l : Boolean;'#013#010+
|
|
|
+ ' FAfterClean: TNotifyEvent;'#013#010+
|
|
|
+ ' FAfterCompile: TNotifyEvent;'#013#010+
|
|
|
+ ' FBeforeClean: TNotifyEvent;'#013#010+
|
|
|
+ ' FBeforeCompile: TNotifyEvent;'#013#010+
|
|
|
+ ' FCPUs: TCPUs;'#013#010+
|
|
|
+ ' FOSes: TOSes;'#013#010+
|
|
|
+ ' FMode: TCompilerMode;'#013#010+
|
|
|
+ ' FResourceStrings: Boole','an;'#013#010+
|
|
|
+ ' FObjectPath,'#013#010+
|
|
|
+ ' FUnitPath,'#013#010+
|
|
|
+ ' FIncludePath : TConditionalStrings;'#013#010+
|
|
|
+ ' FDependencies : TDependencies;'#013#010+
|
|
|
+ ' FCommands : TCommands;'#013#010+
|
|
|
+ ' FDirectory: String;'#013#010+
|
|
|
+ ' FExtension: String;'#013#010+
|
|
|
+ ' FTargetSourceFileName : String;'#013#010+
|
|
|
+ ' FFile','Type: TFileType;'#013#010+
|
|
|
+ ' FOptions: TStrings;'#013#010+
|
|
|
+ ' FFPCTarget: String;'#013#010+
|
|
|
+ ' FTargetState: TTargetState;'#013#010+
|
|
|
+ ' FTargetType: TTargetType;'#013#010+
|
|
|
+ ' FXML: string;'#013#010+
|
|
|
+ ' function GetOptions: TStrings;'#013#010+
|
|
|
+ ' procedure SetOptions(const AValue: TStrings);'#013#010+
|
|
|
+ ' ','Protected'#013#010+
|
|
|
+ ' Function GetSourceFileName : String; virtual;'#013#010+
|
|
|
+ ' Function GetUnitFileName : String; virtual;'#013#010+
|
|
|
+ ' function GetUnitLibFileName: String; virtual;'#013#010+
|
|
|
+ ' Function GetObjectFileName : String; virtual;'#013#010+
|
|
|
+ ' Function GetRSTFileName',' : String; Virtual;'#013#010+
|
|
|
+ ' function GetImportLibFileName(AOS : TOS) : String; Virtual;'#013#010+
|
|
|
+ ' Function GetProgramFileName(AOS : TOS) : String; Virtual;'#013#010+
|
|
|
+ ' Function GetProgramDebugFileName(AOS : TOS) : String; Virtual;'#013+
|
|
|
+ #010+
|
|
|
+ ' Public'#013#010+
|
|
|
+ ' Construct','or Create(ACollection : TCollection); override;'#013#010+
|
|
|
+ ' Destructor Destroy; override;'#013#010+
|
|
|
+ ' procedure AssignTo(Dest: TPersistent); override;'#013#010+
|
|
|
+ ' Function GetOutputFileName (AOs : TOS) : String; Virtual;'#013#010+
|
|
|
+ ' Function HaveOptions : Boolean;'#013#010+
|
|
|
+ ' ',' procedure SetName(const AValue: String);override;'#013#010+
|
|
|
+ ' procedure SetXML(const AValue: string);'#013#010+
|
|
|
' Procedure GetCleanFiles(List : TStrings; const APrefixU, APrefixB '+
|
|
|
- ': String; ACPU:TCPU; AOS : TOS); virtual;'#010+
|
|
|
- ' Procedure GetInstallFiles(List : TStrings; const APrefixU, APrefix'+
|
|
|
- 'B: String; ACPU:TCPU; AOS',' : TOS); virtual;'#010+
|
|
|
+ ': String; ACPU:TCPU; AOS : TOS); virtual;'#013#010+
|
|
|
+ ' Procedure GetInstallFile','s(List : TStrings; const APrefixU, APref'+
|
|
|
+ 'ixB: String; ACPU:TCPU; AOS : TOS); virtual;'#013#010+
|
|
|
' Procedure GetArchiveFiles(List : TStrings; ACPU:TCPU; AOS : TOS); '+
|
|
|
- 'virtual;'#010+
|
|
|
- ' Property Dependencies : TDependencies Read FDependencies;'#010+
|
|
|
- ' Property Commands : TCommands Read FCommands;'#010+
|
|
|
- ' Property State : TTargetSta','te Read FTargetState;'#010+
|
|
|
+ 'virtual;'#013#010+
|
|
|
+ ' Property Dependencies : TDependencies Read FDependencies;'#013#010+
|
|
|
+ ' Propert','y Commands : TCommands Read FCommands;'#013#010+
|
|
|
+ ' Property State : TTargetState Read FTargetState;'#013#010+
|
|
|
' Property TargetType : TTargetType Read FTargetType Write FTargetTy'+
|
|
|
- 'pe;'#010+
|
|
|
- ' Property OSes : TOSes Read FOSes Write FOSes;'#010+
|
|
|
- ' Property CPUs : TCPUs Read FCPUs Write FCPUs;'#010+
|
|
|
- ' Property Mode : TCompilerMode Read FMode',' Write FMode;'#010+
|
|
|
- ' Property Options : TStrings Read GetOptions Write SetOptions;'#010+
|
|
|
- ' Property SourceFileName: String Read GetSourceFileName ;'#010+
|
|
|
- ' Property UnitFileName : String Read GetUnitFileName;'#010+
|
|
|
- ' Property UnitLibFileName : String Read',' GetUnitLibFileName;'#010+
|
|
|
- ' Property ObjectFileName : String Read GetObjectFileName;'#010+
|
|
|
- ' Property RSTFileName : String Read GetRSTFileName;'#010+
|
|
|
- ' Property FPCTarget : String Read FFPCTarget Write FFPCTarget;'#010+
|
|
|
- ' Property Extension : String Read ','FExtension Write FExtension;'#010+
|
|
|
- ' Property FileType : TFileType Read FFileType Write FFileType;'#010+
|
|
|
- ' Property Directory : String Read FDirectory Write FDirectory;'#010+
|
|
|
+ 'pe;'#013#010+
|
|
|
+ ' Property OSes : TOSes Read FOSes Write FOSes;'#013#010+
|
|
|
+ ' Property CPUs : ','TCPUs Read FCPUs Write FCPUs;'#013#010+
|
|
|
+ ' Property Mode : TCompilerMode Read FMode Write FMode;'#013#010+
|
|
|
+ ' Property Options : TStrings Read GetOptions Write SetOptions;'#013#010+
|
|
|
+ ' Property SourceFileName: String Read GetSourceFileName ;'#013#010+
|
|
|
+ ' Property UnitFile','Name : String Read GetUnitFileName;'#013#010+
|
|
|
+ ' Property UnitLibFileName : String Read GetUnitLibFileName;'#013#010+
|
|
|
+ ' Property ObjectFileName : String Read GetObjectFileName;'#013#010+
|
|
|
+ ' Property RSTFileName : String Read GetRSTFileName;'#013#010+
|
|
|
+ ' Property FPCTarge','t : String Read FFPCTarget Write FFPCTarget;'#013+
|
|
|
+ #010+
|
|
|
+ ' Property Extension : String Read FExtension Write FExtension;'#013#010+
|
|
|
+ ' Property FileType : TFileType Read FFileType Write FFileType;'#013#010+
|
|
|
+ ' Property Directory : String Read FDirectory Write FDirec','tory;'#013+
|
|
|
+ #010+
|
|
|
' Property ResourceStrings : Boolean Read FResourceStrings Write FRe'+
|
|
|
- 'sourceStr','ings;'#010+
|
|
|
- ' Property Install : Boolean Read FInstall Write FInstall;'#010+
|
|
|
- ' Property TargetSourceFileName: String Read FTargetSourceFileName;'#010+
|
|
|
- ' Property ObjectPath : TConditionalStrings Read FObjectPath;'#010+
|
|
|
- ' Property UnitPath : TConditionalStr','ings Read FUnitPath;'#010+
|
|
|
- ' Property IncludePath : TConditionalStrings Read FIncludePath;'#010+
|
|
|
- ' Property XML: string Read FXML Write SetXML;'#010+
|
|
|
- ' // Events.'#010+
|
|
|
+ 'sourceStrings;'#013#010+
|
|
|
+ ' Property Install : Boolean Read FInstall Write FInstall;'#013#010+
|
|
|
+ ' Property TargetSourceFileName: String Read FTargetSourceFileName;'#013+
|
|
|
+ #010+
|
|
|
+ ' Property O','bjectPath : TConditionalStrings Read FObjectPath;'#013#010+
|
|
|
+ ' Property UnitPath : TConditionalStrings Read FUnitPath;'#013#010+
|
|
|
+ ' Property IncludePath : TConditionalStrings Read FIncludePath;'#013#010+
|
|
|
+ ' Property XML: string Read FXML Write SetXML;'#013#010+
|
|
|
+ ' // Even','ts.'#013#010+
|
|
|
' Property BeforeCompile : TNotifyEvent Read FBeforeCompile Write FB'+
|
|
|
- 'eforeCompile;'#010+
|
|
|
- ' P','roperty AfterCompile : TNotifyEvent Read FAfterCompile Write FA'+
|
|
|
- 'fterCompile;'#010+
|
|
|
- ' Property BeforeClean : TNotifyEvent Read FBeforeClean Write FBefor'+
|
|
|
- 'eClean;'#010+
|
|
|
+ 'eforeCompile;'#013#010+
|
|
|
+ ' Property AfterCompile : TNotifyEvent Read FAfterCompile Write FAft'+
|
|
|
+ 'erCompile;'#013#010+
|
|
|
+ ' Property BeforeClean : TNotifyEvent Read FBeforeClean Write FBef','o'+
|
|
|
+ 'reClean;'#013#010+
|
|
|
' Property AfterClean : TNotifyEvent Read FAfterClean Write FAfterCl'+
|
|
|
- 'ean;'#010+
|
|
|
- ' end;'#010+
|
|
|
- #010+
|
|
|
- ' {',' TTargets }'#010+
|
|
|
- #010+
|
|
|
- ' TTargets = Class(TNamedCollection)'#010+
|
|
|
- ' private'#010+
|
|
|
- ' function GetTargetItem(Index : Integer): TTarget;'#010+
|
|
|
- ' function GetTarget(const AName : String): TTarget;'#010+
|
|
|
- ' procedure SetTargetItem(Index : Integer; const AValue: TTarget);'#010+
|
|
|
- ' ','Public'#010+
|
|
|
+ 'ean;'#013#010+
|
|
|
+ ' end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ ' { TTargets }'#013#010+
|
|
|
+ #013#010+
|
|
|
+ ' TTargets = Class(TNamedCollection)'#013#010+
|
|
|
+ ' private'#013#010+
|
|
|
+ ' function GetTargetItem(Index : Integer): TTarget;'#013#010+
|
|
|
+ ' function GetTarge','t(const AName : String): TTarget;'#013#010+
|
|
|
+ ' procedure SetTargetItem(Index : Integer; const AValue: TTarget);'#013+
|
|
|
+ #010+
|
|
|
+ ' Public'#013#010+
|
|
|
' Function AddFPDoc(Const AUnitName, AXMLName : String) : TTarget;in'+
|
|
|
- 'line;'#010+
|
|
|
- ' Function AddUnit(Const AUnitName : String) : TTarget;inline;'#010+
|
|
|
+ 'line;'#013#010+
|
|
|
+ ' Function AddUnit(Const AUnitName : String) :',' TTarget;inline;'#013+
|
|
|
+ #010+
|
|
|
' Function AddUnit(Const AUnitName : String;const OSes:TOSes) : TTar'+
|
|
|
- 'get;inline;'#010+
|
|
|
- '{$ifdef cp','u_only_overloads}'#010+
|
|
|
+ 'get;inline;'#013#010+
|
|
|
+ '{$ifdef cpu_only_overloads}'#013#010+
|
|
|
' Function AddUnit(Const AUnitName : String;const CPUs:TCPUs) : TTar'+
|
|
|
- 'get;inline;'#010+
|
|
|
- '{$endif cpu_only_overloads}'#010+
|
|
|
+ 'get;inline;'#013#010+
|
|
|
+ '{$endif cpu_only_overloads}',#013#010+
|
|
|
' Function AddUnit(Const AUnitName : String;const CPUs:TCPUs;const O'+
|
|
|
- 'Ses:TOSes) : TTarget;'#010+
|
|
|
- ' Function AddImpl','icitUnit(Const AUnitName : String;InstallUnit:bo'+
|
|
|
- 'olean=true) : TTarget;inline;'#010+
|
|
|
- ' Function AddImplicitUnit(Const AUnitName : String;const OSes:TOSes'+
|
|
|
- ';InstallUnit:boolean=true) : TTarget;inline;'#010+
|
|
|
- ' Function AddImplicitUnit(Const AUnitName : ','String;const CPUs:TCP'+
|
|
|
- 'Us;InstallUnit:boolean=true) : TTarget;inline;'#010+
|
|
|
+ 'Ses:TOSes) : TTarget;'#013#010+
|
|
|
+ ' Function AddImplicitUnit(Const AUnitName : String;InstallUnit:bool'+
|
|
|
+ 'ean=true) : TTarget;inline;'#013#010+
|
|
|
+ ' Function AddImplicitUnit(Const AUnitName :',' String;const OSes:TOS'+
|
|
|
+ 'es;InstallUnit:boolean=true) : TTarget;inline;'#013#010+
|
|
|
' Function AddImplicitUnit(Const AUnitName : String;const CPUs:TCPUs'+
|
|
|
- ';const OSes:TOSes;InstallUnit:boolean=true) : TTarget;'#010+
|
|
|
- ' Function AddProgram(Const AProgramName : St','ring) : TTarget;inlin'+
|
|
|
- 'e;'#010+
|
|
|
+ ';InstallUnit:boolean=true) : TTarget;inline;'#013#010+
|
|
|
+ ' Function AddImplicitUnit(Const AUnitName : String;','const CPUs:TCP'+
|
|
|
+ 'Us;const OSes:TOSes;InstallUnit:boolean=true) : TTarget;'#013#010+
|
|
|
+ ' Function AddProgram(Const AProgramName : String) : TTarget;inline;'+
|
|
|
+ #013#010+
|
|
|
' Function AddProgram(Const AProgramName : String;const OSes:TOSes) '+
|
|
|
- ': TTarget;inline;'#010+
|
|
|
- '{$ifdef cpu_only_overloads}'#010+
|
|
|
+ ': TTarget;inline;'#013#010+
|
|
|
+ '{$ifdef',' cpu_only_overloads}'#013#010+
|
|
|
' Function AddProgram(Const AProgramName : String;const CPUs:TCPUs) '+
|
|
|
- ': TTarget;inline;'#010+
|
|
|
- '{$endif cpu_','only_overloads}'#010+
|
|
|
+ ': TTarget;inline;'#013#010+
|
|
|
+ '{$endif cpu_only_overloads}'#013#010+
|
|
|
' Function AddProgram(Const AProgramName : String;const CPUs:TCPUs;c'+
|
|
|
- 'onst OSes:TOSes) : TTarget;'#010+
|
|
|
- ' Function AddExampleUnit(Const AUnitName : String) : TTarget;inline'+
|
|
|
- ';'#010+
|
|
|
- ' Function AddExampleUnit(Const AUnitName : String;c','onst OSes:TOSe'+
|
|
|
- 's) : TTarget;inline;'#010+
|
|
|
- '{$ifdef cpu_only_overloads}'#010+
|
|
|
- ' Function AddExampleUnit(Const AUnitName : String;const CPUs:TCPUs)'+
|
|
|
- ' : TTarget;inline;'#010+
|
|
|
- '{$endif cpu_only_overloads}'#010+
|
|
|
- ' Function AddExampleUnit(Const AUnitName : String;const C','PUs:TCPU'+
|
|
|
- 's;const OSes:TOSes) : TTarget;'#010+
|
|
|
- ' Function AddExampleProgram(Const AProgramName : String) : TTarget;'+
|
|
|
- 'inline;'#010+
|
|
|
+ 'onst OSes:TOSes) : TTarget;'#013#010+
|
|
|
+ ' ',' Function AddExampleUnit(Const AUnitName : String) : TTarget;inli'+
|
|
|
+ 'ne;'#013#010+
|
|
|
+ ' Function AddExampleUnit(Const AUnitName : String;const OSes:TOSes)'+
|
|
|
+ ' : TTarget;inline;'#013#010+
|
|
|
+ '{$ifdef cpu_only_overloads}'#013#010+
|
|
|
+ ' Function AddExampleUnit(Const AUnitName : Str','ing;const CPUs:TCPU'+
|
|
|
+ 's) : TTarget;inline;'#013#010+
|
|
|
+ '{$endif cpu_only_overloads}'#013#010+
|
|
|
+ ' Function AddExampleUnit(Const AUnitName : String;const CPUs:TCPUs;'+
|
|
|
+ 'const OSes:TOSes) : TTarget;'#013#010+
|
|
|
+ ' Function AddExampleProgram(Const AProgramName : String) : TTarget;',
|
|
|
+ 'inline;'#013#010+
|
|
|
' Function AddExampleProgram(Const AProgramName : String;const OSes:'+
|
|
|
- 'TOSes) : TTarget;inline;'#010+
|
|
|
- '{$ifdef cpu_only_overloads}'#010,
|
|
|
+ 'TOSes) : TTarget;inline;'#013#010+
|
|
|
+ '{$ifdef cpu_only_overloads}'#013#010+
|
|
|
' Function AddExampleProgram(Const AProgramName : String;const CPUs:'+
|
|
|
- 'TCPUs) : TTarget;inline;'#010+
|
|
|
- '{$endif cpu_only_overloads}'#010+
|
|
|
+ 'TCPUs) : TTarget;inline;'#013#010+
|
|
|
+ '{$endif cp','u_only_overloads}'#013#010+
|
|
|
' Function AddExampleProgram(Const AProgramName : String;const CPUs:'+
|
|
|
- 'TCPUs;const OSes:TOSes) : TTarget;'#010+
|
|
|
- ' Property',' Targets[AName : String] : TTarget Read GetTarget; defau'+
|
|
|
- 'lt;'#010+
|
|
|
- ' Property TargetItems[Index : Integer] : TTarget Read GetTargetItem'+
|
|
|
- ' Write SetTargetItem;'#010+
|
|
|
- ' end;'#010+
|
|
|
- #010+
|
|
|
- ' { TSource }'#010+
|
|
|
- #010+
|
|
|
- ' TSource = Class(TNamedItem)'#010+
|
|
|
- ' private'#010+
|
|
|
- ' FSourceType : TSource','Type;'#010+
|
|
|
- ' FInstallSourcePath : string;'#010+
|
|
|
- ' function GetInstallSourcePath: string;'#010+
|
|
|
- ' Public'#010+
|
|
|
- ' Constructor Create(ACollection : TCollection); override;'#010+
|
|
|
- ' Destructor Destroy; override;'#010+
|
|
|
- ' Procedure GetInstallFiles(List : TStrings); virtua','l;'#010+
|
|
|
- ' property SourceType : TSourceType read FSourceType;'#010+
|
|
|
- ' property InstallSourcePath : string read GetInstallSourcePath;'#010+
|
|
|
- ' end;'#010+
|
|
|
- #010+
|
|
|
- ' { TSources }'#010+
|
|
|
- #010+
|
|
|
- ' TSources = Class(TNamedCollection)'#010+
|
|
|
- ' private'#010+
|
|
|
- ' function GetSourceItem(Index : Integer)',': TSource;'#010+
|
|
|
- ' procedure SetSourceItem(Index : Integer; const AValue: TSource);'#010+
|
|
|
- ' public'#010+
|
|
|
- ' Function AddDoc(const AFiles : String) : TSource;'#010+
|
|
|
+ 'TCPUs;const OSes:TOSes) : TTarget;'#013#010+
|
|
|
+ ' Property Targets[AName : String] : TTarget Read GetTarget; default'+
|
|
|
+ ';'#013#010+
|
|
|
+ ' Property TargetItems[Index : Integer] ',': TTarget Read GetTargetIt'+
|
|
|
+ 'em Write SetTargetItem;'#013#010+
|
|
|
+ ' end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ ' { TSource }'#013#010+
|
|
|
+ #013#010+
|
|
|
+ ' TSource = Class(TNamedItem)'#013#010+
|
|
|
+ ' private'#013#010+
|
|
|
+ ' FSourceType : TSourceType;'#013#010+
|
|
|
+ ' FInstallSourcePath : string;'#013#010+
|
|
|
+ ' function GetInstallSourcePath: string;'#013#010+
|
|
|
+ ' Public'#013#010,
|
|
|
+ ' Constructor Create(ACollection : TCollection); override;'#013#010+
|
|
|
+ ' Destructor Destroy; override;'#013#010+
|
|
|
+ ' Procedure GetInstallFiles(List : TStrings); virtual;'#013#010+
|
|
|
+ ' property SourceType : TSourceType read FSourceType;'#013#010+
|
|
|
+ ' property InstallSourcePa','th : string read GetInstallSourcePath;'#013+
|
|
|
+ #010+
|
|
|
+ ' end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ ' { TSources }'#013#010+
|
|
|
+ #013#010+
|
|
|
+ ' TSources = Class(TNamedCollection)'#013#010+
|
|
|
+ ' private'#013#010+
|
|
|
+ ' function GetSourceItem(Index : Integer): TSource;'#013#010+
|
|
|
+ ' procedure SetSourceItem(Index : Integer; const AValue: TSource);',#013+
|
|
|
+ #010+
|
|
|
+ ' public'#013#010+
|
|
|
+ ' Function AddDoc(const AFiles : String) : TSource;'#013#010+
|
|
|
' Function AddDoc(const AFiles : String; AInstallSourcePath : String'+
|
|
|
- ') : TSource;'#010+
|
|
|
- ' Function A','ddSrc(const AFiles : String) : TSource;'#010+
|
|
|
- ' Function AddExample(const AFiles : String) : TSource;'#010+
|
|
|
+ ') : TSource;'#013#010+
|
|
|
+ ' Function AddSrc(const AFiles : String) : TSource;'#013#010+
|
|
|
+ ' Function AddExample(const AFil','es : String) : TSource;'#013#010+
|
|
|
' Function AddExample(const AFiles : String; AInstallSourcePath : St'+
|
|
|
- 'ring) : TSource;'#010+
|
|
|
- ' Function AddTest(const AFiles : String) : TSource;'#010,
|
|
|
+ 'ring) : TSource;'#013#010+
|
|
|
+ ' Function AddTest(const AFiles : String) : TSource;'#013#010+
|
|
|
' procedure AddDocFiles(const AFileMask: string; Recursive: boolean '+
|
|
|
- '= False; AInstallSourcePath : String = '#039#039');'#010+
|
|
|
+ '=',' False; AInstallSourcePath : String = '#039#039');'#013#010+
|
|
|
' procedure AddSrcFiles(const AFileMask: string; Recursive: boolean '+
|
|
|
- '= False);'#010+
|
|
|
- ' procedure AddExampleFiles(const AFileMask:',' string; Recursive: bo'+
|
|
|
- 'olean = False; AInstallSourcePath : String = '#039#039');'#010+
|
|
|
+ '= False);'#013#010+
|
|
|
+ ' procedure AddExampleFiles(const AFileMask: string; Recursive: bool'+
|
|
|
+ 'ean = False; AInstallSourcePath : String = '#039#039,');'#013#010+
|
|
|
' procedure AddTestFiles(const AFileMask: string; Recursive: boolean'+
|
|
|
- ' = False);'#010+
|
|
|
+ ' = False);'#013#010+
|
|
|
' Property SourceItems[Index : Integer] : TSource Read GetSourceItem'+
|
|
|
- ' Write SetSourceI','tem;default;'#010+
|
|
|
- ' end;'#010+
|
|
|
- #010+
|
|
|
- ' { TPackage }'#010+
|
|
|
- #010+
|
|
|
- ' TPackage = Class(TNamedItem)'#010+
|
|
|
- ' private'#010+
|
|
|
- ' FAfterArchive: TNotifyEvent;'#010+
|
|
|
- ' FAfterArchiveProc: TNotifyProcEvent;'#010+
|
|
|
- ' FAfterClean: TNotifyEvent;'#010+
|
|
|
- ' FAfterCleanProc: TNotifyProcEvent;'#010+
|
|
|
- ' FAfterCompile:',' TNotifyEvent;'#010+
|
|
|
- ' FAfterCompileProc: TNotifyProcEvent;'#010+
|
|
|
- ' FAfterInstall: TNotifyEvent;'#010+
|
|
|
- ' FAfterInstallProc: TNotifyProcEvent;'#010+
|
|
|
- ' FAfterManifest: TNotifyEvent;'#010+
|
|
|
- ' FAfterManifestProc: TNotifyProcEvent;'#010+
|
|
|
- ' FBeforeArchive: TNotifyEvent;'#010,
|
|
|
- ' FBeforeArchiveProc: TNotifyProcEvent;'#010+
|
|
|
- ' FBeforeClean: TNotifyEvent;'#010+
|
|
|
- ' FBeforeCleanProc: TNotifyProcEvent;'#010+
|
|
|
- ' FBeforeCompile: TNotifyEvent;'#010+
|
|
|
- ' FBeforeCompileProc: TNotifyProcEvent;'#010+
|
|
|
- ' FBeforeInstall: TNotifyEvent;'#010+
|
|
|
- ' FBeforeInsta','llProc: TNotifyProcEvent;'#010+
|
|
|
- ' FBeforeManifest: TNotifyEvent;'#010+
|
|
|
- ' FBeforeManifestProc: TNotifyProcEvent;'#010+
|
|
|
- ' FBuildMode: TBuildMode;'#010+
|
|
|
- ' FFlags: TStrings;'#010+
|
|
|
- ' FFPDocFormat: TFPDocFormats;'#010+
|
|
|
- ' FIsFPMakeAddIn: boolean;'#010+
|
|
|
- ' FSupportBuildModes: ','TBuildModes;'#010+
|
|
|
- ' FUnitPath,'#010+
|
|
|
- ' FObjectPath,'#010+
|
|
|
- ' FIncludePath,'#010+
|
|
|
- ' FSourcePath,'#010+
|
|
|
- ' FExamplePath,'#010+
|
|
|
- ' FTestPath,'#010+
|
|
|
- ' FCleanFiles : TConditionalStrings;'#010+
|
|
|
- ' FInstallFiles : TConditionalDestStrings;'#010+
|
|
|
- ' FDependencies : TDependencies;'#010+
|
|
|
- ' FC','PUs: TCPUs;'#010+
|
|
|
- ' FOSes: TOSes;'#010+
|
|
|
- ' FTargetState: TTargetState;'#010+
|
|
|
- ' FTargets: TTargets;'#010+
|
|
|
- ' FSources: TSources;'#010+
|
|
|
- ' FDirectory: String;'#010+
|
|
|
- ' FOptions: TStrings;'#010+
|
|
|
- ' FFileName: String;'#010+
|
|
|
- ' FAuthor: String;'#010+
|
|
|
- ' FLicense: String;'#010+
|
|
|
- ' FHomepageURL',': String;'#010+
|
|
|
- ' FDownloadURL: String;'#010+
|
|
|
- ' FVersion: TFPVersion;'#010+
|
|
|
- ' FEmail : String;'#010+
|
|
|
- ' FNeedLibC : Boolean;'#010+
|
|
|
- ' FCommands : TCommands;'#010+
|
|
|
- ' FDescriptionFile : String;'#010+
|
|
|
- ' FDescription : String;'#010+
|
|
|
- ' FInstalledChecksum : Cardinal;'#010+
|
|
|
- ' FUnitsOu','tputDir: String;'#010+
|
|
|
- ' FPackageUnitInstallDir: String;'#010+
|
|
|
- ' // Cached directory of installed packages'#010+
|
|
|
- ' FUnitDir : String;'#010+
|
|
|
- ' // Used by buildunits'#010+
|
|
|
- ' FBUTargets: TTargets;'#010+
|
|
|
- ' FBUTarget: TTarget;'#010+
|
|
|
- ' // Used to identify if package is bein','g processed by a thread'#010+
|
|
|
- ' FProcessing : boolean;'#010+
|
|
|
- ' // Dictionary'#010+
|
|
|
- ' FDictionary : TDictionary;'#010+
|
|
|
- ' // Is set when all sourcefiles are found'#010+
|
|
|
- ' FAllFilesResolved: boolean;'#010+
|
|
|
- ' FPackageVariants: TFPList;'#010+
|
|
|
- ' Function GetDescription : st','ring;'#010+
|
|
|
- ' function GetDictionary: TDictionary;'#010+
|
|
|
- ' Function GetFileName : string;'#010+
|
|
|
- ' function GetOptions: TStrings;'#010+
|
|
|
- ' Function GetVersion : string;'#010+
|
|
|
- ' procedure SetOptions(const AValue: TStrings);'#010+
|
|
|
- ' Procedure SetVersion(const V : stri','ng);'#010+
|
|
|
- ' Protected'#010+
|
|
|
- ' procedure SetName(const AValue: String);override;'#010+
|
|
|
+ ' Write SetSourceItem;default;'#013#010+
|
|
|
+ ' end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ ' { TPackage }'#013#010+
|
|
|
+ #013#010+
|
|
|
+ ' TPackage = Class(TNamed','Item)'#013#010+
|
|
|
+ ' private'#013#010+
|
|
|
+ ' FAfterArchive: TNotifyEvent;'#013#010+
|
|
|
+ ' FAfterArchiveProc: TNotifyProcEvent;'#013#010+
|
|
|
+ ' FAfterClean: TNotifyEvent;'#013#010+
|
|
|
+ ' FAfterCleanProc: TNotifyProcEvent;'#013#010+
|
|
|
+ ' FAfterCompile: TNotifyEvent;'#013#010+
|
|
|
+ ' FAfterCompileProc: TNotifyProcEvent;',#013#010+
|
|
|
+ ' FAfterInstall: TNotifyEvent;'#013#010+
|
|
|
+ ' FAfterInstallProc: TNotifyProcEvent;'#013#010+
|
|
|
+ ' FAfterManifest: TNotifyEvent;'#013#010+
|
|
|
+ ' FAfterManifestProc: TNotifyProcEvent;'#013#010+
|
|
|
+ ' FBeforeArchive: TNotifyEvent;'#013#010+
|
|
|
+ ' FBeforeArchiveProc: TNotifyProcEvent;'#013#010+
|
|
|
+ ' FB','eforeClean: TNotifyEvent;'#013#010+
|
|
|
+ ' FBeforeCleanProc: TNotifyProcEvent;'#013#010+
|
|
|
+ ' FBeforeCompile: TNotifyEvent;'#013#010+
|
|
|
+ ' FBeforeCompileProc: TNotifyProcEvent;'#013#010+
|
|
|
+ ' FBeforeInstall: TNotifyEvent;'#013#010+
|
|
|
+ ' FBeforeInstallProc: TNotifyProcEvent;'#013#010+
|
|
|
+ ' FBeforeManif','est: TNotifyEvent;'#013#010+
|
|
|
+ ' FBeforeManifestProc: TNotifyProcEvent;'#013#010+
|
|
|
+ ' FBuildMode: TBuildMode;'#013#010+
|
|
|
+ ' FFlags: TStrings;'#013#010+
|
|
|
+ ' FFPDocFormat: TFPDocFormats;'#013#010+
|
|
|
+ ' FIsFPMakeAddIn: boolean;'#013#010+
|
|
|
+ ' FSupportBuildModes: TBuildModes;'#013#010+
|
|
|
+ ' FUnitPath,'#013#010+
|
|
|
+ ' FO','bjectPath,'#013#010+
|
|
|
+ ' FIncludePath,'#013#010+
|
|
|
+ ' FSourcePath,'#013#010+
|
|
|
+ ' FExamplePath,'#013#010+
|
|
|
+ ' FTestPath,'#013#010+
|
|
|
+ ' FCleanFiles : TConditionalStrings;'#013#010+
|
|
|
+ ' FInstallFiles : TConditionalDestStrings;'#013#010+
|
|
|
+ ' FDependencies : TDependencies;'#013#010+
|
|
|
+ ' FCPUs: TCPUs;'#013#010+
|
|
|
+ ' FOSes: TO','Ses;'#013#010+
|
|
|
+ ' FTargetState: TTargetState;'#013#010+
|
|
|
+ ' FTargets: TTargets;'#013#010+
|
|
|
+ ' FSources: TSources;'#013#010+
|
|
|
+ ' FDirectory: String;'#013#010+
|
|
|
+ ' FOptions: TStrings;'#013#010+
|
|
|
+ ' FFileName: String;'#013#010+
|
|
|
+ ' FAuthor: String;'#013#010+
|
|
|
+ ' FLicense: String;'#013#010+
|
|
|
+ ' FHomepageURL: String;'#013#010+
|
|
|
+ ' F','DownloadURL: String;'#013#010+
|
|
|
+ ' FVersion: TFPVersion;'#013#010+
|
|
|
+ ' FEmail : String;'#013#010+
|
|
|
+ ' FNeedLibC : Boolean;'#013#010+
|
|
|
+ ' FCommands : TCommands;'#013#010+
|
|
|
+ ' FDescriptionFile : String;'#013#010+
|
|
|
+ ' FDescription : String;'#013#010+
|
|
|
+ ' FInstalledChecksum : Cardinal;'#013#010+
|
|
|
+ ' FUnitsOutputDir',': String;'#013#010+
|
|
|
+ ' FPackageUnitInstallDir: String;'#013#010+
|
|
|
+ ' // Cached directory of installed packages'#013#010+
|
|
|
+ ' FUnitDir : String;'#013#010+
|
|
|
+ ' // Used by buildunits'#013#010+
|
|
|
+ ' FBUTargets: TTargets;'#013#010+
|
|
|
+ ' FBUTarget: TTarget;'#013#010+
|
|
|
+ ' // Used to identify if package is bein','g processed by a thread'#013+
|
|
|
+ #010+
|
|
|
+ ' FProcessing : boolean;'#013#010+
|
|
|
+ ' // Dictionary'#013#010+
|
|
|
+ ' FDictionary : TDictionary;'#013#010+
|
|
|
+ ' // Is set when all sourcefiles are found'#013#010+
|
|
|
+ ' FAllFilesResolved: boolean;'#013#010+
|
|
|
+ ' FPackageVariants: TFPList;'#013#010+
|
|
|
+ ' Function GetDescripti','on : string;'#013#010+
|
|
|
+ ' function GetDictionary: TDictionary;'#013#010+
|
|
|
+ ' Function GetFileName : string;'#013#010+
|
|
|
+ ' function GetOptions: TStrings;'#013#010+
|
|
|
+ ' Function GetVersion : string;'#013#010+
|
|
|
+ ' procedure SetOptions(const AValue: TStrings);'#013#010+
|
|
|
+ ' Procedure SetVersion(c','onst V : string);'#013#010+
|
|
|
+ ' Protected'#013#010+
|
|
|
+ ' procedure SetName(const AValue: String);override;'#013#010+
|
|
|
' procedure SaveUnitConfigToStringList(Const AStringList: TStrings;A'+
|
|
|
- 'CPU:TCPU;AOS:TOS); virtual;'#010+
|
|
|
- ' property Dictionary: TDictionary read GetDictionary;'#010+
|
|
|
- ' Public'#010+
|
|
|
- ' c','onstructor Create(ACollection: TCollection); override;'#010+
|
|
|
- ' destructor destroy; override;'#010+
|
|
|
- ' Function HaveOptions : Boolean;'#010+
|
|
|
- ' Function GetUnitsOutputDir(ACPU:TCPU; AOS : TOS):String;'#010+
|
|
|
- ' Function GetUnitConfigOutputDir(ACPU:TCPU; AOS :',' TOS):String;'#010+
|
|
|
+ 'CPU:TCPU;AOS:TOS); virtual;'#013#010+
|
|
|
+ ' property Dictionary: TDictionary read GetDictionar','y;'#013#010+
|
|
|
+ ' Public'#013#010+
|
|
|
+ ' constructor Create(ACollection: TCollection); override;'#013#010+
|
|
|
+ ' destructor destroy; override;'#013#010+
|
|
|
+ ' Function HaveOptions : Boolean;'#013#010+
|
|
|
+ ' Function GetUnitsOutputDir(ACPU:TCPU; AOS : TOS):String;'#013#010+
|
|
|
+ ' Function GetUnitConfigOut','putDir(ACPU:TCPU; AOS : TOS):String;'#013+
|
|
|
+ #010+
|
|
|
' Procedure InheritPackageVariantsFromDependency(ADependencyPackage:'+
|
|
|
- ' TPackage);'#010+
|
|
|
+ ' TPackage);'#013#010+
|
|
|
' Function GetPackageVariantsByName(AName: string): TPackageVariant'+
|
|
|
- 's;'#010+
|
|
|
- ' Procedure SetUnitsOutputDir(AValue: string);'#010+
|
|
|
- ' Function GetPacka','geUnitInstallDir(ACPU:TCPU; AOS : TOS):String;'+
|
|
|
- #010+
|
|
|
- ' Procedure SetPackageUnitInstallDir(AValue: string);'#010+
|
|
|
- ' Function GetBinOutputDir(ACPU:TCPU; AOS : TOS) : String;'#010+
|
|
|
- ' Procedure GetCleanFiles(List : TStrings; ACPU:TCPU; AOS : TOS); vi'+
|
|
|
- 'rtual',';'#010+
|
|
|
+ 's;'#013#010+
|
|
|
+ ' Procedure SetUnitsOutputDir(AValue: strin','g);'#013#010+
|
|
|
+ ' Function GetPackageUnitInstallDir(ACPU:TCPU; AOS : TOS):String;'#013+
|
|
|
+ #010+
|
|
|
+ ' Procedure SetPackageUnitInstallDir(AValue: string);'#013#010+
|
|
|
+ ' Function GetBinOutputDir(ACPU:TCPU; AOS : TOS) : String;'#013#010+
|
|
|
+ ' Procedure GetCleanFiles(List : TStrings; ','ACPU:TCPU; AOS : TOS); '+
|
|
|
+ 'virtual;'#013#010+
|
|
|
' procedure GetInstallFiles(List: TStrings;Types : TTargetTypes;ACPU'+
|
|
|
- ':TCPU; AOS : TOS); virtual;'#010+
|
|
|
+ ':TCPU; AOS : TOS); virtual;'#013#010+
|
|
|
' procedure GetInstallSourceFiles(List: TStrings; SourceTypes : TSou'+
|
|
|
- 'rceTypes; TargetTypes : TTargetTypes); virtual;'#010+
|
|
|
- ' Procedure GetArchi','veFiles(List : TStrings; ACPU:TCPU; AOS : TOS)'+
|
|
|
- '; virtual;'#010+
|
|
|
- ' Procedure GetArchiveSourceFiles(List : TStrings); virtual;'#010+
|
|
|
- ' Procedure GetManifest(Manifest : TStrings);'#010+
|
|
|
- ' Procedure AddPackageVariant(APackageVariant: TPackageVariants);'#010+
|
|
|
- ' ','procedure ApplyPackageVariantToCompilerOptions(ACompilerOptions:'+
|
|
|
- ' tstrings);'#010+
|
|
|
- ' procedure SetDefaultPackageVariant;'#010+
|
|
|
- ' procedure LoadUnitConfigFromFile(Const AFileName: String);'#010+
|
|
|
- ' procedure SaveUnitConfigToFile(Const AFileName: String;AC','PU:TCPU'+
|
|
|
- ';AOS:TOS);'#010+
|
|
|
- ' Property Version : String Read GetVersion Write SetVersion;'#010+
|
|
|
- ' Property FileName : String Read GetFileName Write FFileName;'#010+
|
|
|
- ' Property HomepageURL : String Read FHomepageURL Write FHomepageURL'+
|
|
|
- ';'#010+
|
|
|
- ' Property Download','URL : String Read FDownloadURL Write FDownloadU'+
|
|
|
- 'RL;'#010+
|
|
|
- ' Property Email : String Read FEmail Write FEmail;'#010+
|
|
|
- ' Property Author : String Read FAuthor Write FAuthor;'#010+
|
|
|
- ' Property License : String Read FLicense Write FLicense;'#010+
|
|
|
- ' Property Direc','tory : String Read FDirectory Write FDirectory;'#010+
|
|
|
+ 'rceTypes; TargetTypes : TTargetTypes);',' virtual;'#013#010+
|
|
|
+ ' Procedure GetArchiveFiles(List : TStrings; ACPU:TCPU; AOS : TOS); '+
|
|
|
+ 'virtual;'#013#010+
|
|
|
+ ' Procedure GetArchiveSourceFiles(List : TStrings); virtual;'#013#010+
|
|
|
+ ' Procedure GetManifest(Manifest : TStrings);'#013#010+
|
|
|
+ ' Procedure AddPackageVariant(APac','kageVariant: TPackageVariants);'#013+
|
|
|
+ #010+
|
|
|
+ ' procedure ApplyPackageVariantToCompilerOptions(ACompilerOptions: t'+
|
|
|
+ 'strings);'#013#010+
|
|
|
+ ' procedure SetDefaultPackageVariant;'#013#010+
|
|
|
+ ' procedure LoadUnitConfigFromFile(Const AFileName: String);'#013#010+
|
|
|
+ ' procedure SaveUni','tConfigToFile(Const AFileName: String;ACPU:TCPU'+
|
|
|
+ ';AOS:TOS);'#013#010+
|
|
|
+ ' Property Version : String Read GetVersion Write SetVersion;'#013#010+
|
|
|
+ ' Property FileName : String Read GetFileName Write FFileName;'#013#010+
|
|
|
+ ' Property HomepageURL : String Read FHomepageUR','L Write FHomepageU'+
|
|
|
+ 'RL;'#013#010+
|
|
|
+ ' Property DownloadURL : String Read FDownloadURL Write FDownloadURL'+
|
|
|
+ ';'#013#010+
|
|
|
+ ' Property Email : String Read FEmail Write FEmail;'#013#010+
|
|
|
+ ' Property Author : String Read FAuthor Write FAuthor;'#013#010+
|
|
|
+ ' Property License : String R','ead FLicense Write FLicense;'#013#010+
|
|
|
+ ' Property Directory : String Read FDirectory Write FDirectory;'#013#010+
|
|
|
' Property Description : String Read GetDescription Write FDescripti'+
|
|
|
- 'on;'#010+
|
|
|
- ' Property DescriptionFile : String Read FDescriptionFile Write FDes'+
|
|
|
- 'criptionFile;'#010+
|
|
|
- ' Property InstalledChecksum : C','ardinal Read FInstalledChecksum Wr'+
|
|
|
- 'ite FInstalledChecksum;'#010+
|
|
|
+ 'on;'#013#010+
|
|
|
+ ' Property DescriptionFile : String Read FDescriptionFile Write FD','e'+
|
|
|
+ 'scriptionFile;'#013#010+
|
|
|
+ ' Property InstalledChecksum : Cardinal Read FInstalledChecksum Writ'+
|
|
|
+ 'e FInstalledChecksum;'#013#010+
|
|
|
' Property IsFPMakeAddIn: boolean read FIsFPMakeAddIn write FIsFPMak'+
|
|
|
- 'eAddIn;'#010+
|
|
|
- ' Property SupportBuildModes: TBuildModes read FSupportBuildModes wr'+
|
|
|
- 'ite FSupportBuildModes;'#010+
|
|
|
- ' Proper','ty BuildMode: TBuildMode read FBuildMode;'#010+
|
|
|
- ' Property Flags: TStrings read FFlags;'#010+
|
|
|
- ' // Compiler options.'#010+
|
|
|
- ' Property OSes : TOSes Read FOSes Write FOSes;'#010+
|
|
|
- ' Property CPUs : TCPUs Read FCPUs Write FCPUs;'#010+
|
|
|
- ' Property NeedLibC : Boolean',' Read FNeedLibC Write FNeedLibC;'#010+
|
|
|
- ' Property Options: TStrings Read GetOptions Write SetOptions;'#010+
|
|
|
- ' Property UnitPath : TConditionalStrings Read FUnitPath;'#010+
|
|
|
- ' Property ObjectPath : TConditionalStrings Read FObjectPath;'#010+
|
|
|
- ' Property Inclu','dePath : TConditionalStrings Read FIncludePath;'#010+
|
|
|
- ' Property SourcePath : TConditionalStrings Read FSourcePath;'#010+
|
|
|
- ' Property ExamplePath : TConditionalStrings Read FExamplePath;'#010+
|
|
|
- ' Property TestPath : TConditionalStrings Read FTestPath;'#010+
|
|
|
- ' ',' Property FPDocFormat: TFPDocFormats read FFPDocFormat write FFPD'+
|
|
|
- 'ocFormat;'#010+
|
|
|
- ' // Targets and dependencies'#010+
|
|
|
- ' Property InstallFiles : TConditionalDestStrings Read FInstallFiles'+
|
|
|
- ';'#010+
|
|
|
- ' Property CleanFiles : TConditionalStrings Read FCleanFil','es;'#010+
|
|
|
- ' Property Dependencies : TDependencies Read FDependencies;'#010+
|
|
|
- ' Property Commands : TCommands Read FCommands;'#010+
|
|
|
- ' Property State : TTargetState Read FTargetState;'#010+
|
|
|
- ' Property Targets : TTargets Read FTargets;'#010+
|
|
|
- ' Property Sources : T','Sources Read FSources;'#010+
|
|
|
- ' Property UnitDir : String Read FUnitDir Write FUnitDir;'#010+
|
|
|
- ' // events'#010+
|
|
|
- ' Property BeforeCompile : TNotifyEvent Read FBeforeCompile Write FB'+
|
|
|
- 'eforeCompile;'#010+
|
|
|
- ' Property BeforeCompileProc : TNotifyProcEvent Read FBef','oreCompil'+
|
|
|
- 'eProc write FBeforeCompileProc;'#010+
|
|
|
+ 'eAddIn;'#013#010+
|
|
|
+ ' Property SupportBuildModes: TBuildModes read FS','upportBuildModes '+
|
|
|
+ 'write FSupportBuildModes;'#013#010+
|
|
|
+ ' Property BuildMode: TBuildMode read FBuildMode;'#013#010+
|
|
|
+ ' Property Flags: TStrings read FFlags;'#013#010+
|
|
|
+ ' // Compiler options.'#013#010+
|
|
|
+ ' Property OSes : TOSes Read FOSes Write FOSes;'#013#010+
|
|
|
+ ' Property CPUs : TCP','Us Read FCPUs Write FCPUs;'#013#010+
|
|
|
+ ' Property NeedLibC : Boolean Read FNeedLibC Write FNeedLibC;'#013#010+
|
|
|
+ ' Property Options: TStrings Read GetOptions Write SetOptions;'#013#010+
|
|
|
+ ' Property UnitPath : TConditionalStrings Read FUnitPath;'#013#010+
|
|
|
+ ' Property ObjectP','ath : TConditionalStrings Read FObjectPath;'#013#010+
|
|
|
+ ' Property IncludePath : TConditionalStrings Read FIncludePath;'#013#010+
|
|
|
+ ' Property SourcePath : TConditionalStrings Read FSourcePath;'#013#010+
|
|
|
+ ' Property ExamplePath : TConditionalStrings Read FExamplePat','h;'#013+
|
|
|
+ #010+
|
|
|
+ ' Property TestPath : TConditionalStrings Read FTestPath;'#013#010+
|
|
|
+ ' Property FPDocFormat: TFPDocFormats read FFPDocFormat write FFPDoc'+
|
|
|
+ 'Format;'#013#010+
|
|
|
+ ' // Targets and dependencies'#013#010+
|
|
|
+ ' Property InstallFiles : TConditionalDestStrings Read FInsta','llFil'+
|
|
|
+ 'es;'#013#010+
|
|
|
+ ' Property CleanFiles : TConditionalStrings Read FCleanFiles;'#013#010+
|
|
|
+ ' Property Dependencies : TDependencies Read FDependencies;'#013#010+
|
|
|
+ ' Property Commands : TCommands Read FCommands;'#013#010+
|
|
|
+ ' Property State : TTargetState Read FTargetState',';'#013#010+
|
|
|
+ ' Property Targets : TTargets Read FTargets;'#013#010+
|
|
|
+ ' Property Sources : TSources Read FSources;'#013#010+
|
|
|
+ ' Property UnitDir : String Read FUnitDir Write FUnitDir;'#013#010+
|
|
|
+ ' // events'#013#010+
|
|
|
+ ' Property BeforeCompile : TNotifyEvent Read FBeforeCompile Wri','te '+
|
|
|
+ 'FBeforeCompile;'#013#010+
|
|
|
+ ' Property BeforeCompileProc : TNotifyProcEvent Read FBeforeCompileP'+
|
|
|
+ 'roc write FBeforeCompileProc;'#013#010+
|
|
|
' Property AfterCompile : TNotifyEvent Read FAfterCompile Write FAft'+
|
|
|
- 'erCompile;'#010+
|
|
|
- ' Property AfterCompileProc : TNotifyProcEvent Read FAfterCompilePro'+
|
|
|
- 'c Write FAfterCompileProc;'#010+
|
|
|
- ' Property BeforeIn','stall : TNotifyEvent Read FBeforeInstall Write '+
|
|
|
- 'FBeforeInstall;'#010+
|
|
|
+ 'erCompile;'#013#010+
|
|
|
+ ' Property AfterCompileProc : TNoti','fyProcEvent Read FAfterCompileP'+
|
|
|
+ 'roc Write FAfterCompileProc;'#013#010+
|
|
|
+ ' Property BeforeInstall : TNotifyEvent Read FBeforeInstall Write FB'+
|
|
|
+ 'eforeInstall;'#013#010+
|
|
|
' Property BeforeInstallProc : TNotifyProcEvent Read FBeforeInstallP'+
|
|
|
- 'roc Write FBeforeInstallProc;'#010+
|
|
|
+ 'roc Write FBeforeInstall','Proc;'#013#010+
|
|
|
' Property AfterInstall : TNotifyEvent Read FAfterInstall Write FAft'+
|
|
|
- 'erInsta','ll;'#010+
|
|
|
+ 'erInstall;'#013#010+
|
|
|
' Property AfterInstallProc : TNotifyProcEvent Read FAfterInstallPro'+
|
|
|
- 'c Write FAfterInstallProc;'#010+
|
|
|
- ' Property BeforeClean : TNotifyEvent Read FBeforeClean Write FBefor'+
|
|
|
- 'eClean;'#010+
|
|
|
- ' Property BeforeCleanProc : TNotifyProcEvent Read FBeforeC','leanPro'+
|
|
|
- 'c Write FBeforeCleanProc;'#010+
|
|
|
+ 'c Write FAfterInstallProc;'#013#010+
|
|
|
+ ' Property BeforeClean : TNotifyEvent Read FBeforeC','lean Write FBef'+
|
|
|
+ 'oreClean;'#013#010+
|
|
|
+ ' Property BeforeCleanProc : TNotifyProcEvent Read FBeforeCleanProc '+
|
|
|
+ 'Write FBeforeCleanProc;'#013#010+
|
|
|
' Property AfterClean : TNotifyEvent Read FAfterClean Write FAfterCl'+
|
|
|
- 'ean;'#010+
|
|
|
- ' Property AfterCleanProc : TNotifyProcEvent Read FAfterCleanProc Wr'+
|
|
|
- 'ite FAfterCleanProc;'#010+
|
|
|
- ' Property BeforeArchive : TNotifyEvent',' Read FBeforeArchive Write '+
|
|
|
- 'FBeforeArchive;'#010+
|
|
|
+ 'ean;'#013#010+
|
|
|
+ ' Property AfterCleanProc : TNotifyProcEv','ent Read FAfterCleanProc '+
|
|
|
+ 'Write FAfterCleanProc;'#013#010+
|
|
|
+ ' Property BeforeArchive : TNotifyEvent Read FBeforeArchive Write FB'+
|
|
|
+ 'eforeArchive;'#013#010+
|
|
|
' Property BeforeArchiveProc : TNotifyProcEvent Read FBeforeArchiveP'+
|
|
|
- 'roc Write FBeforeArchiveProc;'#010+
|
|
|
- ' Property AfterArchive : TNotifyEvent Read FAfterArchive Write FAft'+
|
|
|
- 'erArchive;'#010+
|
|
|
- ' Property Aft','erArchiveProc : TNotifyProcEvent Read FAfterArchiveP'+
|
|
|
- 'roc Write FAfterArchiveProc;'#010+
|
|
|
- ' Property BeforeManifest : TNotifyEvent Read FBeforeManifest Write '+
|
|
|
- 'FBeforeManifest;'#010+
|
|
|
+ 'roc Write FBeforeArchiveProc;'#013#010+
|
|
|
+ ' P','roperty AfterArchive : TNotifyEvent Read FAfterArchive Write FA'+
|
|
|
+ 'fterArchive;'#013#010+
|
|
|
+ ' Property AfterArchiveProc : TNotifyProcEvent Read FAfterArchivePro'+
|
|
|
+ 'c Write FAfterArchiveProc;'#013#010+
|
|
|
+ ' Property BeforeManifest : TNotifyEvent Read FBeforeManifest W','rit'+
|
|
|
+ 'e FBeforeManifest;'#013#010+
|
|
|
' Property BeforeManifestProc : TNotifyProcEvent Read FBeforeManifes'+
|
|
|
- 'tP','roc Write FBeforeManifestProc;'#010+
|
|
|
+ 'tProc Write FBeforeManifestProc;'#013#010+
|
|
|
' Property AfterManifest : TNotifyEvent Read FAfterManifest Write FA'+
|
|
|
- 'fterManifest;'#010+
|
|
|
- ' Property AfterManifestProc : TNotifyProcEvent Read FAfterManifestP'+
|
|
|
- 'roc Write FAfterManifestProc;'#010+
|
|
|
- ' end;'#010+
|
|
|
- #010+
|
|
|
- ' { TPackages }'#010+
|
|
|
- #010,
|
|
|
- ' TPackages = Class(TNamedCollection)'#010+
|
|
|
- ' private'#010+
|
|
|
- ' function GetPackage(const AName : String): TPackage;'#010+
|
|
|
- ' function GetPackageItem(AIndex : Integer): TPackage;'#010+
|
|
|
+ 'fterManifest;'#013#010+
|
|
|
+ ' Property AfterManifestPr','oc : TNotifyProcEvent Read FAfterManifes'+
|
|
|
+ 'tProc Write FAfterManifestProc;'#013#010+
|
|
|
+ ' end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ ' { TPackages }'#013#010+
|
|
|
+ #013#010+
|
|
|
+ ' TPackages = Class(TNamedCollection)'#013#010+
|
|
|
+ ' private'#013#010+
|
|
|
+ ' function GetPackage(const AName : String): TPackage;'#013#010+
|
|
|
+ ' function GetPackageItem(AI','ndex : Integer): TPackage;'#013#010+
|
|
|
' procedure SetPackageItem(AIndex : Integer; const AValue: TPackage)'+
|
|
|
- ';'#010+
|
|
|
- ' Publ','ic'#010+
|
|
|
- ' Function AddPackage(Const AName : String) : TPackage;'#010+
|
|
|
- ' Property Packages[AName : String] : TPackage Read GetPackage ; Def'+
|
|
|
- 'ault;'#010+
|
|
|
+ ';'#013#010+
|
|
|
+ ' Public'#013#010+
|
|
|
+ ' Function AddPackage(Const AName : String) : TPackage;'#013#010+
|
|
|
+ ' Property Packages[AName : String] : TPackage Read GetPackage ; Def',
|
|
|
+ 'ault;'#013#010+
|
|
|
' Property PackageItems[AIndex : Integer] : TPackage Read GetPackage'+
|
|
|
- 'Item Write SetPackageItem;'#010+
|
|
|
- ' end;',#010+
|
|
|
- #010+
|
|
|
- ' { TCustomDefaults }'#010+
|
|
|
- #010+
|
|
|
- ' TCustomDefaults = Class(TPersistent)'#010+
|
|
|
- ' Private'#010+
|
|
|
- ' FArchive: String;'#010+
|
|
|
- ' FBuildMode: TBuildMode;'#010+
|
|
|
- ' FCompiler: String;'#010+
|
|
|
- ' FCopy: String;'#010+
|
|
|
- ' FFPDocOutputDir: String;'#010+
|
|
|
- ' FIgnoreInvalidOptions: Boolean;'#010+
|
|
|
- ' FInst','allExamples: Boolean;'#010+
|
|
|
- ' FMkDir: String;'#010+
|
|
|
- ' FMove: String;'#010+
|
|
|
- ' FOptions: TStrings;'#010+
|
|
|
- ' FCPU: TCPU;'#010+
|
|
|
- ' FOS: TOS;'#010+
|
|
|
- ' FMode : TCompilerMode;'#010+
|
|
|
- ' FCompilerVersion : String;'#010+
|
|
|
- ' FPrefix: String;'#010+
|
|
|
- ' FLocalUnitDir,'#010+
|
|
|
- ' FGlobalUnitDir,'#010+
|
|
|
- ' FBa','seInstallDir,'#010+
|
|
|
- ' FUnitInstallDir,'#010+
|
|
|
- ' FBinInstallDir,'#010+
|
|
|
- ' FDocInstallDir,'#010+
|
|
|
- ' FExamplesInstallDir : String;'#010+
|
|
|
- ' FSkipCrossPrograms: boolean;'#010+
|
|
|
- ' FThreadsAmount: integer;'#010+
|
|
|
- ' FRemoveTree: String;'#010+
|
|
|
- ' FRemoveDir: String;'#010+
|
|
|
- ' FRemove: String;',#010+
|
|
|
- ' FTarget: String;'#010+
|
|
|
- ' FUnixPaths: Boolean;'#010+
|
|
|
- ' FNoFPCCfg: Boolean;'#010+
|
|
|
- ' FUseEnvironment: Boolean;'#010+
|
|
|
- ' function GetBuildCPU: TCpu;'#010+
|
|
|
- ' function GetBuildOS: TOS;'#010+
|
|
|
- ' function GetBuildString: String;'#010+
|
|
|
- ' function GetFPDocOutputDir: String;'#010,
|
|
|
- ' function GetLocalUnitDir: String;'#010+
|
|
|
- ' function GetGlobalUnitDir: String;'#010+
|
|
|
- ' function GetBaseInstallDir: String;'#010+
|
|
|
- ' function GetBinInstallDir: String;'#010+
|
|
|
- ' function GetCompiler: String;'#010+
|
|
|
- ' function GetDocInstallDir: String;'#010+
|
|
|
- ' functio','n GetExamplesInstallDir: String;'#010+
|
|
|
- ' function GetOptions: TStrings;'#010+
|
|
|
- ' function GetUnitInstallDir: String;'#010+
|
|
|
- ' procedure SetLocalUnitDir(const AValue: String);'#010+
|
|
|
- ' procedure SetGlobalUnitDir(const AValue: String);'#010+
|
|
|
- ' procedure IntSetBaseI','nstallDir(const AValue: String);'#010+
|
|
|
- ' procedure SetBaseInstallDir(const AValue: String);'#010+
|
|
|
- ' procedure SetCPU(const AValue: TCPU);'#010+
|
|
|
- ' procedure SetOptions(const AValue: TStrings);'#010+
|
|
|
- ' procedure SetOS(const AValue: TOS);'#010+
|
|
|
- ' procedure SetPre','fix(const AValue: String);'#010+
|
|
|
- ' procedure SetTarget(const AValue: String);'#010+
|
|
|
- ' procedure SetUnitInstallDir(const AValue: String);'#010+
|
|
|
- ' Protected'#010+
|
|
|
- ' procedure RecalcTarget;'#010+
|
|
|
- ' Function CmdLineOptions : String;'#010+
|
|
|
- ' Public'#010+
|
|
|
- ' Constructor Create;'#010,
|
|
|
- ' Procedure InitDefaults;'#010+
|
|
|
- ' Function HaveOptions: Boolean;'#010+
|
|
|
- ' function IsBuildDifferentFromTarget: boolean;'#010+
|
|
|
- ' procedure CompilerDefaults; virtual;'#010+
|
|
|
- ' Procedure LocalInit(Const AFileName : String);'#010+
|
|
|
- ' Procedure LoadFromFile(Const AF','ileName : String);'#010+
|
|
|
- ' Procedure SaveToFile(Const AFileName : String);'#010+
|
|
|
- ' procedure SaveToStream(S : TStream);virtual;'#010+
|
|
|
- ' procedure LoadFromStream(S : TStream);virtual;'#010+
|
|
|
- ' // Compile Information'#010+
|
|
|
- ' Property Target : String Read FTarget ','Write SetTarget;'#010+
|
|
|
- ' Property OS : TOS Read FOS Write SetOS;'#010+
|
|
|
- ' Property CPU : TCPU Read FCPU Write SetCPU;'#010+
|
|
|
- ' Property BuildString : String read GetBuildString;'#010+
|
|
|
- ' Property BuildOS : TOS read GetBuildOS;'#010+
|
|
|
- ' Property BuildCPU : TCpu rea','d GetBuildCPU;'#010+
|
|
|
- ' Property Mode : TCompilerMode Read FMode Write FMode;'#010+
|
|
|
- ' Property UnixPaths : Boolean Read FUnixPaths Write FUnixPaths;'#010+
|
|
|
+ 'Item Write SetPackageItem;'#013#010+
|
|
|
+ ' end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ ' { TCustomDefaults }'#013#010+
|
|
|
+ #013#010+
|
|
|
+ ' TCustomDefaults = Class(TPersistent)'#013#010+
|
|
|
+ ' Private'#013#010+
|
|
|
+ ' FArchive: String;'#013#010+
|
|
|
+ ' FBuildMode: TBuildMode',';'#013#010+
|
|
|
+ ' FCompiler: String;'#013#010+
|
|
|
+ ' FCopy: String;'#013#010+
|
|
|
+ ' FFPDocOutputDir: String;'#013#010+
|
|
|
+ ' FIgnoreInvalidOptions: Boolean;'#013#010+
|
|
|
+ ' FInstallExamples: Boolean;'#013#010+
|
|
|
+ ' FMkDir: String;'#013#010+
|
|
|
+ ' FMove: String;'#013#010+
|
|
|
+ ' FOptions: TStrings;'#013#010+
|
|
|
+ ' FCPU: TCPU;'#013#010+
|
|
|
+ ' FOS: TO','S;'#013#010+
|
|
|
+ ' FMode : TCompilerMode;'#013#010+
|
|
|
+ ' FCompilerVersion : String;'#013#010+
|
|
|
+ ' FPrefix: String;'#013#010+
|
|
|
+ ' FLocalUnitDir,'#013#010+
|
|
|
+ ' FGlobalUnitDir,'#013#010+
|
|
|
+ ' FBaseInstallDir,'#013#010+
|
|
|
+ ' FUnitInstallDir,'#013#010+
|
|
|
+ ' FBinInstallDir,'#013#010+
|
|
|
+ ' FDocInstallDir,'#013#010+
|
|
|
+ ' FExamplesInstallDir : S','tring;'#013#010+
|
|
|
+ ' FSkipCrossPrograms: boolean;'#013#010+
|
|
|
+ ' FThreadsAmount: integer;'#013#010+
|
|
|
+ ' FRemoveTree: String;'#013#010+
|
|
|
+ ' FRemoveDir: String;'#013#010+
|
|
|
+ ' FRemove: String;'#013#010+
|
|
|
+ ' FTarget: String;'#013#010+
|
|
|
+ ' FUnixPaths: Boolean;'#013#010+
|
|
|
+ ' FNoFPCCfg: Boolean;'#013#010+
|
|
|
+ ' FUseEnvironment: B','oolean;'#013#010+
|
|
|
+ ' function GetBuildCPU: TCpu;'#013#010+
|
|
|
+ ' function GetBuildOS: TOS;'#013#010+
|
|
|
+ ' function GetBuildString: String;'#013#010+
|
|
|
+ ' function GetFPDocOutputDir: String;'#013#010+
|
|
|
+ ' function GetLocalUnitDir: String;'#013#010+
|
|
|
+ ' function GetGlobalUnitDir: String;'#013#010+
|
|
|
+ ' funct','ion GetBaseInstallDir: String;'#013#010+
|
|
|
+ ' function GetBinInstallDir: String;'#013#010+
|
|
|
+ ' function GetCompiler: String;'#013#010+
|
|
|
+ ' function GetDocInstallDir: String;'#013#010+
|
|
|
+ ' function GetExamplesInstallDir: String;'#013#010+
|
|
|
+ ' function GetOptions: TStrings;'#013#010+
|
|
|
+ ' function',' GetUnitInstallDir: String;'#013#010+
|
|
|
+ ' procedure SetLocalUnitDir(const AValue: String);'#013#010+
|
|
|
+ ' procedure SetGlobalUnitDir(const AValue: String);'#013#010+
|
|
|
+ ' procedure IntSetBaseInstallDir(const AValue: String);'#013#010+
|
|
|
+ ' procedure SetBaseInstallDir(const AValu','e: String);'#013#010+
|
|
|
+ ' procedure SetCPU(const AValue: TCPU);'#013#010+
|
|
|
+ ' procedure SetOptions(const AValue: TStrings);'#013#010+
|
|
|
+ ' procedure SetOS(const AValue: TOS);'#013#010+
|
|
|
+ ' procedure SetPrefix(const AValue: String);'#013#010+
|
|
|
+ ' procedure SetTarget(const AValue: String',');'#013#010+
|
|
|
+ ' procedure SetUnitInstallDir(const AValue: String);'#013#010+
|
|
|
+ ' Protected'#013#010+
|
|
|
+ ' procedure RecalcTarget;'#013#010+
|
|
|
+ ' Function CmdLineOptions : String;'#013#010+
|
|
|
+ ' Public'#013#010+
|
|
|
+ ' Constructor Create;'#013#010+
|
|
|
+ ' Procedure InitDefaults;'#013#010+
|
|
|
+ ' Function HaveOptions: Boolean;'#013,#010+
|
|
|
+ ' function IsBuildDifferentFromTarget: boolean;'#013#010+
|
|
|
+ ' procedure CompilerDefaults; virtual;'#013#010+
|
|
|
+ ' Procedure LocalInit(Const AFileName : String);'#013#010+
|
|
|
+ ' Procedure LoadFromFile(Const AFileName : String);'#013#010+
|
|
|
+ ' Procedure SaveToFile(Const AFileNam','e : String);'#013#010+
|
|
|
+ ' procedure SaveToStream(S : TStream);virtual;'#013#010+
|
|
|
+ ' procedure LoadFromStream(S : TStream);virtual;'#013#010+
|
|
|
+ ' // Compile Information'#013#010+
|
|
|
+ ' Property Target : String Read FTarget Write SetTarget;'#013#010+
|
|
|
+ ' Property OS : TOS Read FOS Write',' SetOS;'#013#010+
|
|
|
+ ' Property CPU : TCPU Read FCPU Write SetCPU;'#013#010+
|
|
|
+ ' Property BuildString : String read GetBuildString;'#013#010+
|
|
|
+ ' Property BuildOS : TOS read GetBuildOS;'#013#010+
|
|
|
+ ' Property BuildCPU : TCpu read GetBuildCPU;'#013#010+
|
|
|
+ ' Property Mode : TCompilerMode',' Read FMode Write FMode;'#013#010+
|
|
|
+ ' Property UnixPaths : Boolean Read FUnixPaths Write FUnixPaths;'#013+
|
|
|
+ #010+
|
|
|
' Property Options : TStrings Read GetOptions Write SetOptions; /'+
|
|
|
- '/ Default compiler options.'#010+
|
|
|
- ' ',' Property NoFPCCfg : Boolean Read FNoFPCCfg Write FNoFPCCfg;'#010+
|
|
|
+ '/ Default compiler options.'#013#010+
|
|
|
+ ' Property NoFPCCfg : Boolean Read FNoFPCCfg ','Write FNoFPCCfg;'#013#010+
|
|
|
' // When ThreadsAmount is specified, #threadsamount# worker-threads'+
|
|
|
- ' are'#010+
|
|
|
+ ' are'#013#010+
|
|
|
' // created. When such a worker-thread is ready all worker-threads '+
|
|
|
- 'are evaluated'#010+
|
|
|
- ' // to see if th','ere are idle threads (there is always at least on'+
|
|
|
- 'e such thread.)'#010+
|
|
|
+ 'are evaluated'#013#010+
|
|
|
+ ' // to see if there are idle threads (there is always at l','east on'+
|
|
|
+ 'e such thread.)'#013#010+
|
|
|
' // To each idle thread a package is assigned which has to be compi'+
|
|
|
- 'led for the'#010+
|
|
|
+ 'led for the'#013#010+
|
|
|
' // current target and for which all dependencies are compiled earl'+
|
|
|
- 'ier.'#010+
|
|
|
- ' // When no pac','kage is available the thread remains idle until an'+
|
|
|
- 'other thread'#010+
|
|
|
+ 'ier.'#013#010+
|
|
|
+ ' // When no package is available the thread remains id','le until an'+
|
|
|
+ 'other thread'#013#010+
|
|
|
' // has finished it'#039's task. Compilation stops when all packages'+
|
|
|
- ' are compiled'#010+
|
|
|
- ' // or when an error occures.'#010+
|
|
|
- ' //'#010+
|
|
|
- ' // When ThreadsAmount is not specified (-1), all pack','ages are co'+
|
|
|
- 'mpiled on by one.'#010+
|
|
|
- ' // Dependencies are compiled recursively. When a package is alread'+
|
|
|
- 'y compiled'#010+
|
|
|
+ ' are compiled'#013#010+
|
|
|
+ ' // or when an error occures.'#013#010+
|
|
|
+ ' //'#013#010+
|
|
|
+ ' // When ThreadsAmount is not specified (-1), all packages are comp'+
|
|
|
+ 'iled on by one.'#013#010+
|
|
|
+ ' /','/ Dependencies are compiled recursively. When a package is alre'+
|
|
|
+ 'ady compiled'#013#010+
|
|
|
' // (because some other package was depending on it) the package is'+
|
|
|
- ' skipped.'#010+
|
|
|
- ' // When the last package in the list is compil','ed, the compilatio'+
|
|
|
- 'n stops.'#010+
|
|
|
- ' Property ThreadsAmount : integer Read FThreadsAmount Write FThread'+
|
|
|
- 'sAmount;'#010+
|
|
|
- ' // paths etc.'#010+
|
|
|
+ ' skipped.'#013#010+
|
|
|
+ ' // When the last package in the list is compiled, the compilation '+
|
|
|
+ 'stops.'#013#010+
|
|
|
+ ' ','Property ThreadsAmount : integer Read FThreadsAmount Write FThre'+
|
|
|
+ 'adsAmount;'#013#010+
|
|
|
+ ' // paths etc.'#013#010+
|
|
|
' Property LocalUnitDir : String Read GetLocalUnitDir Write SetLocal'+
|
|
|
- 'UnitDir;'#010+
|
|
|
- ' Property GlobalUnitDir : String R','ead GetGlobalUnitDir Write SetG'+
|
|
|
- 'lobalUnitDir;'#010+
|
|
|
- ' Property Prefix : String Read FPrefix Write SetPrefix;'#010+
|
|
|
+ 'UnitDir;'#013#010+
|
|
|
+ ' Property GlobalUnitDir : String Read GetGlobalUnitDir Write S','etG'+
|
|
|
+ 'lobalUnitDir;'#013#010+
|
|
|
+ ' Property Prefix : String Read FPrefix Write SetPrefix;'#013#010+
|
|
|
' Property BaseInstallDir : String Read GetBaseInstallDir Write SetB'+
|
|
|
- 'aseInstallDir;'#010+
|
|
|
- ' Property UnitInstallDir : String Read GetUnitIn','stallDir Write Se'+
|
|
|
- 'tUnitInstallDir;'#010+
|
|
|
+ 'aseInstallDir;'#013#010+
|
|
|
+ ' Property UnitInstallDir : String Read GetUnitInstallDir Write SetU'+
|
|
|
+ 'nitIns','tallDir;'#013#010+
|
|
|
' Property BinInstallDir : String Read GetBinInstallDir Write FBinIn'+
|
|
|
- 'stallDir;'#010+
|
|
|
+ 'stallDir;'#013#010+
|
|
|
' Property DocInstallDir : String Read GetDocInstallDir Write FDocIn'+
|
|
|
- 'stallDir;'#010+
|
|
|
- ' Property ExamplesInstallDir : String Read ','GetExamplesInstallDir '+
|
|
|
- 'Write FExamplesInstallDir;'#010+
|
|
|
+ 'stallDir;'#013#010+
|
|
|
+ ' Property ExamplesInstallDir : String Read GetExamplesInstallDir ','W'+
|
|
|
+ 'rite FExamplesInstallDir;'#013#010+
|
|
|
' Property FPDocOutputDir : String Read GetFPDocOutputDir Write FFPD'+
|
|
|
- 'ocOutputDir;'#010+
|
|
|
- ' // Command tools. If not set, internal commands will be used.'#010+
|
|
|
- ' Property Compiler : String Read GetCo','mpiler Write FCompiler; // '+
|
|
|
- 'Compiler. Defaults to fpc'#010+
|
|
|
+ 'ocOutputDir;'#013#010+
|
|
|
+ ' // Command tools. If not set, internal commands will be used.'#013+
|
|
|
+ #010+
|
|
|
+ ' Property Compiler : String Read GetCompiler Write FCompi','ler; // '+
|
|
|
+ 'Compiler. Defaults to fpc'#013#010+
|
|
|
' Property Copy : String Read FCopy Write FCopy; // copy'+
|
|
|
- ' $(FILES) to $(DEST)'#010+
|
|
|
+ ' $(FILES) to $(DEST)'#013#010+
|
|
|
' Property Move : String Read FMove Write FMove; // Move'+
|
|
|
- ' $(FILES) to $(DEST)'#010+
|
|
|
- ' P','roperty Remove : String Read FRemove Write FRemove; // De'+
|
|
|
- 'lete $(FILES)'#010+
|
|
|
+ ' $(FILES) to $(DEST)'#013#010+
|
|
|
+ ' Property Remove :',' String Read FRemove Write FRemove; // De'+
|
|
|
+ 'lete $(FILES)'#013#010+
|
|
|
' Property RemoveDir : String Read FRemoveDir Write FRemoveDir; '+
|
|
|
- ' // Delete $(FILES)'#010+
|
|
|
+ ' // Delete $(FILES)'#013#010+
|
|
|
' Property RemoveTree : String Read FRemoveTree Write FRemoveTree; '+
|
|
|
- ' ',' // removes $(DIRECTORY)'#010+
|
|
|
+ ' // removes ','$(DIRECTORY)'#013#010+
|
|
|
' Property MkDir : String Read FMkDir write FMkDir; // Make'+
|
|
|
- ' $(DIRECTORY)'#010+
|
|
|
+ ' $(DIRECTORY)'#013#010+
|
|
|
' Property Archive : String Read FArchive Write FArchive; // zip '+
|
|
|
- '$(ARCHIVE) $(FILESORDIRS)'#010+
|
|
|
- ' // Misc'#010+
|
|
|
- ' Property UseEnvir','onment : Boolean read FUseEnvironment write FUs'+
|
|
|
- 'eEnvironment;'#010+
|
|
|
+ '$(ARCHIVE) $(FILESORDIRS)'#013#010+
|
|
|
+ ' // Misc'#013#010+
|
|
|
+ ' Property UseEnvironment : B','oolean read FUseEnvironment write FUs'+
|
|
|
+ 'eEnvironment;'#013#010+
|
|
|
' Property IgnoreInvalidOptions: Boolean read FIgnoreInvalidOptions '+
|
|
|
- 'write FIgnoreInvalidOptions;'#010+
|
|
|
- ' Property BuildMode: TBuildMode read FBuildMode write FBuildMode;'#010+
|
|
|
- ' // Inst','allation optioms'#010+
|
|
|
+ 'write FIgnoreInvalidOptions;'#013#010+
|
|
|
+ ' Property BuildMode: TBuildMode read FBuildMode write FBuildMode;'#013+
|
|
|
+ #010+
|
|
|
+ ' // Installatio','n optioms'#013#010+
|
|
|
' Property InstallExamples: Boolean read FInstallExamples write FIns'+
|
|
|
- 'tallExamples;'#010+
|
|
|
+ 'tallExamples;'#013#010+
|
|
|
' Property SkipCrossPrograms: boolean read FSkipCrossPrograms write '+
|
|
|
- 'FSkipCrossPrograms;'#010+
|
|
|
- ' end;'#010+
|
|
|
- #010+
|
|
|
- ' { TBasicDefaults }'#010+
|
|
|
- #010+
|
|
|
- ' TBasicDefaults = ','Class(TCustomDefaults)'#010+
|
|
|
- ' end;'#010+
|
|
|
- #010+
|
|
|
- ' { TFPCDefaults }'#010+
|
|
|
- #010+
|
|
|
- ' TFPCDefaults = Class(TCustomDefaults)'#010+
|
|
|
- ' public'#010+
|
|
|
- ' procedure CompilerDefaults; override;'#010+
|
|
|
- ' end;'#010+
|
|
|
- #010+
|
|
|
- ' { TBuildEngine }'#010+
|
|
|
- #010+
|
|
|
- ' TBuildEngine = Class(TComponent)'#010+
|
|
|
- ' private'#010+
|
|
|
- ' // general variables'#010,
|
|
|
- ' FCompiler : String;'#010+
|
|
|
- ' FStartDir : String;'#010+
|
|
|
- ' FForceCompile : Boolean;'#010+
|
|
|
- ' FListMode : Boolean;'#010+
|
|
|
- ' FVerbose : boolean;'#010+
|
|
|
- ' FProgressMax : integer;'#010+
|
|
|
- ' FProgressCount : integer;'#010+
|
|
|
- '{$ifdef HAS_UNIT_ZIPPER}'#010+
|
|
|
- ' FZipFile: TZipper;'#010+
|
|
|
- '{$endif ','HAS_UNIT_ZIPPER}'#010+
|
|
|
- ' FExternalPackages : TPackages;'#010+
|
|
|
- ' // Events'#010+
|
|
|
- ' FOnLog: TLogEvent;'#010+
|
|
|
- ' FAfterArchive: TNotifyEvent;'#010+
|
|
|
- ' FAfterClean: TNotifyEvent;'#010+
|
|
|
- ' FAfterCompile: TNotifyEvent;'#010+
|
|
|
- ' FAfterInstall: TNotifyEvent;'#010+
|
|
|
- ' FAfterManifest: T','NotifyEvent;'#010+
|
|
|
- ' FBeforeArchive: TNotifyEvent;'#010+
|
|
|
- ' FBeforeClean: TNotifyEvent;'#010+
|
|
|
- ' FBeforeCompile: TNotifyEvent;'#010+
|
|
|
- ' FBeforeInstall: TNotifyEvent;'#010+
|
|
|
- ' FBeforeManifest: TNotifyEvent;'#010+
|
|
|
- ' FZipper: TZipper;'#010+
|
|
|
- ' Protected'#010+
|
|
|
- ' Procedure Error(cons','t Msg : String);'#010+
|
|
|
- ' Procedure Error(const Fmt : String; const Args : Array of const);'#010+
|
|
|
- ' // Internal copy/delete/move/archive/mkdir files'#010+
|
|
|
- ' Function SysDirectoryExists(const ADir:string):Boolean;'#010+
|
|
|
- ' Function SysFileExists(const AFile','Name:string):Boolean;'#010+
|
|
|
- ' Procedure SysCopyFile(Const Src,Dest : String); virtual;'#010+
|
|
|
- ' Procedure SysMoveFile(Const Src,Dest : String); virtual;'#010+
|
|
|
- ' Procedure SysDeleteFile(Const AFileName : String); virtual;'#010+
|
|
|
- ' Procedure SysDeleteDirectory','(Const ADirectoryName : String); vir'+
|
|
|
- 'tual;'#010+
|
|
|
- ' Procedure SysDeleteTree(Const ADirectoryName : String); virtual;'#010+
|
|
|
+ 'FSkipCrossPrograms;'#013#010+
|
|
|
+ ' end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ ' { TBasicDefaults }'#013#010+
|
|
|
+ #013#010+
|
|
|
+ ' TBasicDefaults = ','Class(TCustomDefaults)'#013#010+
|
|
|
+ ' end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ ' { TFPCDefaults }'#013#010+
|
|
|
+ #013#010+
|
|
|
+ ' TFPCDefaults = Class(TCustomDefaults)'#013#010+
|
|
|
+ ' public'#013#010+
|
|
|
+ ' procedure CompilerDefaults; override;'#013#010+
|
|
|
+ ' end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ ' { TBuildEngine }'#013#010+
|
|
|
+ #013#010+
|
|
|
+ ' TBuildEngine = Class(TComponent)'#013#010+
|
|
|
+ ' private'#013#010+
|
|
|
+ ' // gene','ral variables'#013#010+
|
|
|
+ ' FCompiler : String;'#013#010+
|
|
|
+ ' FStartDir : String;'#013#010+
|
|
|
+ ' FForceCompile : Boolean;'#013#010+
|
|
|
+ ' FListMode : Boolean;'#013#010+
|
|
|
+ ' FVerbose : boolean;'#013#010+
|
|
|
+ ' FProgressMax : integer;'#013#010+
|
|
|
+ ' FProgressCount : integer;'#013#010+
|
|
|
+ '{$ifdef HAS_UNIT_ZIPPER}'#013#010+
|
|
|
+ ' FZip','File: TZipper;'#013#010+
|
|
|
+ '{$endif HAS_UNIT_ZIPPER}'#013#010+
|
|
|
+ ' FExternalPackages : TPackages;'#013#010+
|
|
|
+ ' // Events'#013#010+
|
|
|
+ ' FOnLog: TLogEvent;'#013#010+
|
|
|
+ ' FAfterArchive: TNotifyEvent;'#013#010+
|
|
|
+ ' FAfterClean: TNotifyEvent;'#013#010+
|
|
|
+ ' FAfterCompile: TNotifyEvent;'#013#010+
|
|
|
+ ' FAfterInstall: TNot','ifyEvent;'#013#010+
|
|
|
+ ' FAfterManifest: TNotifyEvent;'#013#010+
|
|
|
+ ' FBeforeArchive: TNotifyEvent;'#013#010+
|
|
|
+ ' FBeforeClean: TNotifyEvent;'#013#010+
|
|
|
+ ' FBeforeCompile: TNotifyEvent;'#013#010+
|
|
|
+ ' FBeforeInstall: TNotifyEvent;'#013#010+
|
|
|
+ ' FBeforeManifest: TNotifyEvent;'#013#010+
|
|
|
+ ' FZipper: TZipper',';'#013#010+
|
|
|
+ ' Protected'#013#010+
|
|
|
+ ' Procedure Error(const Msg : String);'#013#010+
|
|
|
+ ' Procedure Error(const Fmt : String; const Args : Array of const);'#013+
|
|
|
+ #010+
|
|
|
+ ' // Internal copy/delete/move/archive/mkdir files'#013#010+
|
|
|
+ ' Function SysDirectoryExists(const ADir:string):Boole','an;'#013#010+
|
|
|
+ ' Function SysFileExists(const AFileName:string):Boolean;'#013#010+
|
|
|
+ ' Procedure SysCopyFile(Const Src,Dest : String); virtual;'#013#010+
|
|
|
+ ' Procedure SysMoveFile(Const Src,Dest : String); virtual;'#013#010+
|
|
|
+ ' Procedure SysDeleteFile(Const AFileName : Str','ing); virtual;'#013#010+
|
|
|
+ ' Procedure SysDeleteDirectory(Const ADirectoryName : String); virtu'+
|
|
|
+ 'al;'#013#010+
|
|
|
+ ' Procedure SysDeleteTree(Const ADirectoryName : String); virtual;'#013+
|
|
|
+ #010+
|
|
|
' Procedure SysArchiveFiles(List : TStrings; Const AFileName : Strin'+
|
|
|
- 'g); virtual;'#010+
|
|
|
- ' procedure LogIndent;'#010+
|
|
|
- ' procedure LogUnIn','dent;'#010+
|
|
|
- ' Procedure EnterDir(ADir : String);'#010+
|
|
|
- ' Function GetCompiler : String;'#010+
|
|
|
+ 'g); virtu','al;'#013#010+
|
|
|
+ ' procedure LogIndent;'#013#010+
|
|
|
+ ' procedure LogUnIndent;'#013#010+
|
|
|
+ ' Procedure EnterDir(ADir : String);'#013#010+
|
|
|
+ ' Function GetCompiler : String;'#013#010+
|
|
|
' Function InstallPackageFiles(APAckage : TPackage; tt : TTargetType'+
|
|
|
- 's; Const Dest : String):Boolean;'#010+
|
|
|
- ' Procedure InstallUnitConfigFile(APAckage : TPackage; ','Const Dest '+
|
|
|
- ': String);'#010+
|
|
|
+ 's; Const Dest : String):Boolean;'#013#010+
|
|
|
+ ' ',' Procedure InstallUnitConfigFile(APAckage : TPackage; Const Dest '+
|
|
|
+ ': String);'#013#010+
|
|
|
' Function InstallPackageSourceFiles(APAckage : TPackage; stt : TSou'+
|
|
|
- 'rceTypes; ttt : TTargetTypes; Const Dest : String):Boolean;'#010+
|
|
|
- ' Function FileNewer(const Src,Dest : String) : Boolean;'#010+
|
|
|
- ' Procedure LogSearchPath(A','Package: TPackage;const ASearchPathName'+
|
|
|
- ':string;Path:TConditionalStrings; ACPU:TCPU;AOS:TOS);'#010+
|
|
|
+ 'rceTypes; ttt : TTargetTypes; Const Dest : String):Boolean;'#013#010+
|
|
|
+ ' Function FileNewer(const S','rc,Dest : String) : Boolean;'#013#010+
|
|
|
+ ' Procedure LogSearchPath(APackage: TPackage;const ASearchPathName:s'+
|
|
|
+ 'tring;Path:TConditionalStrings; ACPU:TCPU;AOS:TOS);'#013#010+
|
|
|
' Function FindFileInPath(APackage: TPackage; Path:TConditionalStrin'+
|
|
|
- 'gs; AFileName:String; var FoundPath:String;ACPU:TCPU;AOS:TOS):Boolean;'+
|
|
|
- #010+
|
|
|
- #010+
|
|
|
- ' p','rocedure GetDirectoriesFromFilelist(const AFileList, ADirectory'+
|
|
|
- 'List: TStringList);'#010+
|
|
|
- ' //package commands'#010+
|
|
|
- ' function GetUnitDir(APackage:TPackage):String;'#010+
|
|
|
- ' procedure AddDependencyPaths(L: TStrings; DependencyType: TDepende'+
|
|
|
- 'ncyType; ATa','rget: TTarget);'#010+
|
|
|
- ' procedure AddDependencyUnitPaths(L:TStrings;APackage: TPackage);'#010+
|
|
|
- ' Public'#010+
|
|
|
- ' Constructor Create(AOwner : TComponent); override;'#010+
|
|
|
- ' destructor Destroy;override;'#010+
|
|
|
- ' function AddPathPrefix(APackage: TPackage; APath: stri','ng): strin'+
|
|
|
- 'g;'#010+
|
|
|
- #010+
|
|
|
- ' property Verbose : boolean read FVerbose write FVerbose;'#010+
|
|
|
+ 'gs; AFileName:Str','ing; var FoundPath:String;ACPU:TCPU;AOS:TOS):Boolea'+
|
|
|
+ 'n;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ ' procedure GetDirectoriesFromFilelist(const AFileList, ADirectoryLi'+
|
|
|
+ 'st: TStringList);'#013#010+
|
|
|
+ ' //package commands'#013#010+
|
|
|
+ ' function GetUnitDir(APackage:TPackage):String;'#013#010+
|
|
|
+ ' procedure Add','DependencyPaths(L: TStrings; DependencyType: TDepen'+
|
|
|
+ 'dencyType; ATarget: TTarget);'#013#010+
|
|
|
+ ' procedure AddDependencyUnitPaths(L:TStrings;APackage: TPackage);'#013+
|
|
|
+ #010+
|
|
|
+ ' Public'#013#010+
|
|
|
+ ' Constructor Create(AOwner : TComponent); override;'#013#010+
|
|
|
+ ' destructor Destroy',';override;'#013#010+
|
|
|
+ ' function AddPathPrefix(APackage: TPackage; APath: string): string;'+
|
|
|
+ #013#010+
|
|
|
+ #013#010+
|
|
|
+ ' property Verbose : boolean read FVerbose write FVerbose;'#013#010+
|
|
|
' Procedure ResolveFileNames(APackage : TPackage; ACPU:TCPU;AOS:TOS;'+
|
|
|
- 'DoChangeDir:boolean=true; WarnIfNotFound:boolean=true);'#010+
|
|
|
- #010+
|
|
|
- ' // Public Copy/delete/Move/Archive','/Mkdir Commands.'#010+
|
|
|
+ 'DoChangeDir:boolean=tr','ue; WarnIfNotFound:boolean=true);'#013#010+
|
|
|
+ #013#010+
|
|
|
+ ' // Public Copy/delete/Move/Archive/Mkdir Commands.'#013#010+
|
|
|
' Procedure ExecuteCommand(const Cmd,Args : String; const Env: TStri'+
|
|
|
- 'ngs = nil; IgnoreError : Boolean = False); virtual;'#010+
|
|
|
- ' Procedure CmdCopyFiles(List : TStrings; Const DestDir : String);'#010+
|
|
|
- ' Procedure CmdCreateDir(const',' DestDir : String);'#010+
|
|
|
- ' Procedure CmdMoveFiles(List : TStrings; Const DestDir : String);'#010+
|
|
|
- ' Procedure CmdDeleteFiles(List : TStrings);'#010+
|
|
|
- ' Procedure CmdArchiveFiles(List : TStrings; Const ArchiveFile : Str'+
|
|
|
- 'ing);'#010+
|
|
|
- ' Procedure CmdRenameFile(','SourceName, DestName : String);'#010+
|
|
|
- ' Procedure CmdRemoveDirs(List: TStrings);'#010+
|
|
|
- ' Procedure CmdRemoveTrees(List: TStrings);'#010+
|
|
|
- ' Procedure ExecuteCommands(Commands : TCommands; At : TCommandAt; A'+
|
|
|
- 'Package: TPackage = nil);'#010+
|
|
|
- ' // Dependency com','mands'#010+
|
|
|
- ' Function DependencyOK(ADependency : TDependency) : Boolean;'#010+
|
|
|
- ' // Target commands'#010+
|
|
|
- ' Function GetCompilerCommand(APackage : TPackage; ATarget : TTarge'+
|
|
|
- 't; Env: TStrings) : String;'#010+
|
|
|
- ' Function TargetOK(ATarget : TTarget; ACPU: ','TCPU; AOS: TOS) : Bo'+
|
|
|
- 'olean;'#010+
|
|
|
+ 'ngs = nil; IgnoreError : Boolean = False); virtual;'#013#010+
|
|
|
+ ' Procedure CmdCopyFil','es(List : TStrings; Const DestDir : String);'+
|
|
|
+ #013#010+
|
|
|
+ ' Procedure CmdCreateDir(const DestDir : String);'#013#010+
|
|
|
+ ' Procedure CmdMoveFiles(List : TStrings; Const DestDir : String);'#013+
|
|
|
+ #010+
|
|
|
+ ' Procedure CmdDeleteFiles(List : TStrings);'#013#010+
|
|
|
+ ' Procedure CmdArchiv','eFiles(List : TStrings; Const ArchiveFile : S'+
|
|
|
+ 'tring);'#013#010+
|
|
|
+ ' Procedure CmdRenameFile(SourceName, DestName : String);'#013#010+
|
|
|
+ ' Procedure CmdRemoveDirs(List: TStrings);'#013#010+
|
|
|
+ ' Procedure CmdRemoveTrees(List: TStrings);'#013#010+
|
|
|
+ ' Procedure ExecuteCommands(Co','mmands : TCommands; At : TCommandAt;'+
|
|
|
+ ' APackage: TPackage = nil);'#013#010+
|
|
|
+ ' // Dependency commands'#013#010+
|
|
|
+ ' Function DependencyOK(ADependency : TDependency) : Boolean;'#013#010+
|
|
|
+ ' // Target commands'#013#010+
|
|
|
+ ' Function GetCompilerCommand(APackage : TPackage; ATa','rget : TTar'+
|
|
|
+ 'get; Env: TStrings) : String;'#013#010+
|
|
|
+ ' Function TargetOK(ATarget : TTarget; ACPU: TCPU; AOS: TOS) : Bool'+
|
|
|
+ 'ean;'#013#010+
|
|
|
' Function TargetInstallOK(ATarget : TTarget;ACPU:TCPU; AOS : TOS) '+
|
|
|
- ': Boolean;'#010+
|
|
|
- ' Function NeedsCompile(APackage:TPackage; ATarget : TTarget) : Boo'+
|
|
|
- 'lean;'#010+
|
|
|
- ' Procedure Compile(APackage:TPackage; ATarget : TTarg','et); virtua'+
|
|
|
- 'l;'#010+
|
|
|
- ' Procedure MaybeCompile(APackage:TPackage; ATarget: TTarget);'#010+
|
|
|
- ' Procedure CompileDependencies(APackage:TPackage; ATarget: TTarget)'+
|
|
|
- ';'#010+
|
|
|
- ' // Package commands'#010+
|
|
|
- '{ Function GetPackageDir(APackage : TPackage; AbsolutePath :',' Boo'+
|
|
|
- 'lean = False) : String;'#010+
|
|
|
+ ': Boolean;'#013#010+
|
|
|
+ ' Function NeedsCompile(APackage:TPac','kage; ATarget : TTarget) : B'+
|
|
|
+ 'oolean;'#013#010+
|
|
|
+ ' Procedure Compile(APackage:TPackage; ATarget : TTarget); virtual;'+
|
|
|
+ #013#010+
|
|
|
+ ' Procedure MaybeCompile(APackage:TPackage; ATarget: TTarget);'#013#010+
|
|
|
+ ' Procedure CompileDependencies(APackage:TPackage; ATarget: TTa','rge'+
|
|
|
+ 't);'#013#010+
|
|
|
+ ' // Package commands'#013#010+
|
|
|
+ '{ Function GetPackageDir(APackage : TPackage; AbsolutePath : Boole'+
|
|
|
+ 'an = False) : String;'#013#010+
|
|
|
' Function GetUnitsOutputDir(APackage : TPackage; AbsolutePath : Bo'+
|
|
|
- 'olean = False) : String;'#010+
|
|
|
- ' Function GetBinOutputDir(APackage : TPackage; AbsolutePath : Bool'+
|
|
|
- 'ean = False) : String; }'#010+
|
|
|
- ' Function Package','OK(APackage : TPackage) : Boolean; virtual;'#010+
|
|
|
- ' Procedure DoBeforeCompile(APackage : TPackage);virtual;'#010+
|
|
|
- ' Procedure DoAfterCompile(APackage : TPackage);virtual;'#010+
|
|
|
- ' Procedure DoBeforeInstall(APackage : TPackage);virtual;'#010+
|
|
|
- ' Procedure DoA','fterInstall(APackage : TPackage);virtual;'#010+
|
|
|
- ' Procedure DoBeforeArchive(APackage : TPackage);virtual;'#010+
|
|
|
- ' Procedure DoAfterArchive(APackage : TPackage);virtual;'#010+
|
|
|
- ' Procedure DoBeforeClean(APackage : TPackage);virtual;'#010+
|
|
|
- ' Procedure DoAfter','Clean(APackage : TPackage);virtual;'#010+
|
|
|
- ' Function NeedsCompile(APackage : TPackage) : Boolean; virtual;'#010+
|
|
|
- ' Procedure Compile(APackage : TPackage);'#010+
|
|
|
- ' Procedure MaybeCompile(APackage:TPackage);'#010+
|
|
|
- ' Function ReadyToCompile(APackage:TPackage',') : Boolean;'#010+
|
|
|
- ' Procedure Install(APackage : TPackage);'#010+
|
|
|
- ' Procedure Archive(APackage : TPackage);'#010+
|
|
|
- ' Procedure Manifest(APackage : TPackage);'#010+
|
|
|
- ' Procedure Clean(APackage : TPackage; AllTargets: boolean);'#010+
|
|
|
- ' Procedure Clean(APackage : ','TPackage; ACPU:TCPU; AOS : TOS);'#010+
|
|
|
- ' Procedure CompileDependencies(APackage : TPackage);'#010+
|
|
|
- ' function CheckDependencies(APackage : TPackage): TCheckDependencyR'+
|
|
|
- 'esult;'#010+
|
|
|
+ 'olean = False) : String;'#013#010+
|
|
|
+ ' Function GetB','inOutputDir(APackage : TPackage; AbsolutePath : Bo'+
|
|
|
+ 'olean = False) : String; }'#013#010+
|
|
|
+ ' Function PackageOK(APackage : TPackage) : Boolean; virtual;'#013#010+
|
|
|
+ ' Procedure DoBeforeCompile(APackage : TPackage);virtual;'#013#010+
|
|
|
+ ' Procedure DoAfterCompile(APack','age : TPackage);virtual;'#013#010+
|
|
|
+ ' Procedure DoBeforeInstall(APackage : TPackage);virtual;'#013#010+
|
|
|
+ ' Procedure DoAfterInstall(APackage : TPackage);virtual;'#013#010+
|
|
|
+ ' Procedure DoBeforeArchive(APackage : TPackage);virtual;'#013#010+
|
|
|
+ ' Procedure DoAfterArchive(APa','ckage : TPackage);virtual;'#013#010+
|
|
|
+ ' Procedure DoBeforeClean(APackage : TPackage);virtual;'#013#010+
|
|
|
+ ' Procedure DoAfterClean(APackage : TPackage);virtual;'#013#010+
|
|
|
+ ' Function NeedsCompile(APackage : TPackage) : Boolean; virtual;'#013+
|
|
|
+ #010+
|
|
|
+ ' Procedure Compile(APac','kage : TPackage);'#013#010+
|
|
|
+ ' Procedure MaybeCompile(APackage:TPackage);'#013#010+
|
|
|
+ ' Function ReadyToCompile(APackage:TPackage) : Boolean;'#013#010+
|
|
|
+ ' Procedure Install(APackage : TPackage);'#013#010+
|
|
|
+ ' Procedure Archive(APackage : TPackage);'#013#010+
|
|
|
+ ' Procedure Manifest(A','Package : TPackage);'#013#010+
|
|
|
+ ' Procedure Clean(APackage : TPackage; AllTargets: boolean);'#013#010+
|
|
|
+ ' Procedure Clean(APackage : TPackage; ACPU:TCPU; AOS : TOS);'#013#010+
|
|
|
+ ' Procedure CompileDependencies(APackage : TPackage);'#013#010+
|
|
|
+ ' function CheckDependencies(A','Package : TPackage): TCheckDependenc'+
|
|
|
+ 'yResult;'#013#010+
|
|
|
' Function CheckExternalPackage(Const APackageName : String):TPacka'+
|
|
|
- 'ge;'#010,
|
|
|
- ' procedure CreateOutputDir(APackage: TPackage);'#010+
|
|
|
- ' // Packages commands'#010+
|
|
|
- ' Procedure Compile(Packages : TPackages);'#010+
|
|
|
- ' Procedure Install(Packages : TPackages);'#010+
|
|
|
- ' Procedure ZipInstall(Packages : TPackages);'#010+
|
|
|
- ' Procedure Archive(Pack','ages : TPackages);'#010+
|
|
|
- ' procedure Manifest(Packages: TPackages);'#010+
|
|
|
- ' Procedure Clean(Packages : TPackages; AllTargets: boolean);'#010+
|
|
|
- #010+
|
|
|
- ' Procedure Log(Level : TVerboseLevel; Msg : String);'#010+
|
|
|
- ' Procedure Log(Level : TVerboseLevel; Fmt : String; ','const Args : '+
|
|
|
- 'Array Of Const);'#010+
|
|
|
- #010+
|
|
|
- ' Property ListMode : Boolean Read FListMode Write FListMode;'#010+
|
|
|
- ' Property ForceCompile : Boolean Read FForceCompile Write FForceCom'+
|
|
|
- 'pile;'#010+
|
|
|
- ' Property ExternalPackages: TPackages Read FExternalPackages;'#010+
|
|
|
- ' ','Property StartDir: String Read FStartDir;'#010+
|
|
|
- ' // Events'#010+
|
|
|
- ' Property BeforeCompile : TNotifyEvent Read FBeforeCompile Write FB'+
|
|
|
- 'eforeCompile;'#010+
|
|
|
+ 'ge;'#013#010+
|
|
|
+ ' procedure CreateOutputDir(APackage: TPackage);'#013#010+
|
|
|
+ ' // Packages commands'#013#010+
|
|
|
+ ' Procedure Compile(Packages : TPackage','s);'#013#010+
|
|
|
+ ' Procedure Install(Packages : TPackages);'#013#010+
|
|
|
+ ' Procedure ZipInstall(Packages : TPackages);'#013#010+
|
|
|
+ ' Procedure Archive(Packages : TPackages);'#013#010+
|
|
|
+ ' procedure Manifest(Packages: TPackages);'#013#010+
|
|
|
+ ' Procedure Clean(Packages : TPackages; AllTar','gets: boolean);'#013#010+
|
|
|
+ #013#010+
|
|
|
+ ' Procedure Log(Level : TVerboseLevel; Msg : String);'#013#010+
|
|
|
+ ' Procedure Log(Level : TVerboseLevel; Fmt : String; const Args : Ar'+
|
|
|
+ 'ray Of Const);'#013#010+
|
|
|
+ #013#010+
|
|
|
+ ' Property ListMode : Boolean Read FListMode Write FListMode;'#013#010+
|
|
|
+ ' Propert','y ForceCompile : Boolean Read FForceCompile Write FForceC'+
|
|
|
+ 'ompile;'#013#010+
|
|
|
+ ' Property ExternalPackages: TPackages Read FExternalPackages;'#013#010+
|
|
|
+ ' Property StartDir: String Read FStartDir;'#013#010+
|
|
|
+ ' // Events'#013#010+
|
|
|
+ ' Property BeforeCompile : TNotifyEvent Read',' FBeforeCompile Write '+
|
|
|
+ 'FBeforeCompile;'#013#010+
|
|
|
' Property AfterCompile : TNotifyEvent Read FAfterCompile Write FAft'+
|
|
|
- 'erCompile;'#010+
|
|
|
- ' Property Before','Install : TNotifyEvent Read FBeforeInstall Write '+
|
|
|
- 'FBeforeInstall;'#010+
|
|
|
- ' Property AfterInstall : TNotifyEvent Read FAfterInstall Write FAft'+
|
|
|
- 'erInstall;'#010+
|
|
|
+ 'erCompile;'#013#010+
|
|
|
+ ' Property BeforeInstall : TNotifyEvent Read FBeforeInstall Write FB'+
|
|
|
+ 'eforeInstall;'#013#010+
|
|
|
+ ' Property AfterInstall : TNotif','yEvent Read FAfterInstall Write FA'+
|
|
|
+ 'fterInstall;'#013#010+
|
|
|
' Property BeforeClean : TNotifyEvent Read FBeforeClean Write FBefor'+
|
|
|
- 'eClean;'#010+
|
|
|
- ' Property Aft','erClean : TNotifyEvent Read FAfterClean Write FAfter'+
|
|
|
- 'Clean;'#010+
|
|
|
- ' Property BeforeArchive : TNotifyEvent Read FBeforeArchive Write FB'+
|
|
|
- 'eforeArchive;'#010+
|
|
|
+ 'eClean;'#013#010+
|
|
|
+ ' Property AfterClean : TNotifyEvent Read FAfterClean Write FAfterCl'+
|
|
|
+ 'ean;'#013#010+
|
|
|
+ ' Property BeforeArchive : TNotifyE','vent Read FBeforeArchive Write '+
|
|
|
+ 'FBeforeArchive;'#013#010+
|
|
|
' Property AfterArchive : TNotifyEvent Read FAfterArchive Write FAft'+
|
|
|
- 'erArchive;'#010+
|
|
|
- ' Property Bef','oreManifest : TNotifyEvent Read FBeforeManifest Writ'+
|
|
|
- 'e FBeforeManifest;'#010+
|
|
|
- ' Property AfterManifest : TNotifyEvent Read FAfterManifest Write FA'+
|
|
|
- 'fterManifest;'#010+
|
|
|
- ' Property OnLog : TLogEvent Read FOnLog Write FOnlog;'#010+
|
|
|
- ' end;'#010+
|
|
|
- #010+
|
|
|
- ' { TCustomInstaller',' }'#010+
|
|
|
- #010+
|
|
|
- ' TCustomInstaller = Class(TComponent)'#010+
|
|
|
- ' private'#010+
|
|
|
- ' FBuildEngine: TBuildEngine;'#010+
|
|
|
- ' FPackages: TPackages;'#010+
|
|
|
- ' FRunMode: TRunMode;'#010+
|
|
|
- ' FListMode : Boolean;'#010+
|
|
|
- ' FLogLevels : TVerboseLevels;'#010+
|
|
|
- ' FFPMakeOptionsString: string;'#010+
|
|
|
- ' FPackageV','ariantSettings: TStrings;'#010+
|
|
|
- ' FPackageVariants: TFPList;'#010+
|
|
|
- ' Protected'#010+
|
|
|
- ' Procedure Log(Level : TVerboseLevel; Const Msg : String);'#010+
|
|
|
- ' Procedure CreatePackages; virtual;'#010+
|
|
|
- ' Procedure FreePackages; virtual;'#010+
|
|
|
- ' function GetPackages: TPackag','es; virtual;'#010+
|
|
|
- ' Procedure CheckPackages; virtual;'#010+
|
|
|
- ' Procedure CreateBuildEngine; virtual;'#010+
|
|
|
- ' Procedure Error(const Msg : String);'#010+
|
|
|
- ' Procedure Error(const Fmt : String; Args : Array of const);'#010+
|
|
|
- ' Procedure AnalyzeOptions;'#010+
|
|
|
- ' Procedur','e Usage(const FMT : String; Args : Array of const);'#010+
|
|
|
- ' Procedure Compile(Force : Boolean); virtual;'#010+
|
|
|
- ' Procedure Clean(AllTargets: boolean); virtual;'#010+
|
|
|
- ' Procedure Install; virtual;'#010+
|
|
|
- ' Procedure ZipInstall; virtual;'#010+
|
|
|
- ' Procedure Archive','; virtual;'#010+
|
|
|
- ' Procedure Manifest; virtual;'#010+
|
|
|
- ' Public'#010+
|
|
|
- ' Constructor Create(AOwner : TComponent); virtual;'#010+
|
|
|
- ' Destructor destroy; override;'#010+
|
|
|
- ' Function AddPackage(Const AName : String) : TPackage;'#010+
|
|
|
- ' Function AddPackageVariant(AName: st','ring; AIsInheritable: boole'+
|
|
|
- 'an): TPackageVariants;'#010+
|
|
|
- ' Function Run : Boolean;'#010+
|
|
|
- ' Property FPMakeOptionsString: string read FFPMakeOptionsString;'#010+
|
|
|
- ' Property BuildEngine : TBuildEngine Read FBuildEngine;'#010+
|
|
|
- ' //files in package'#010+
|
|
|
- ' Property',' Packages : TPackages Read GetPackages;'#010+
|
|
|
- ' Property RunMode : TRunMode Read FRunMode;'#010+
|
|
|
- ' Property ListMode : Boolean Read FListMode;'#010+
|
|
|
- ' end;'#010+
|
|
|
- #010+
|
|
|
- ' { TFPCInstaller }'#010+
|
|
|
- ' TFPCInstaller = class(TCustomInstaller)'#010+
|
|
|
- ' public'#010+
|
|
|
- ' Constructor Create(AOw','ner : TComponent); override;'#010+
|
|
|
- ' end;'#010+
|
|
|
- #010+
|
|
|
- ' { TBasicInstaller }'#010+
|
|
|
- ' TBasicInstaller = class(TCustomInstaller)'#010+
|
|
|
- ' Constructor Create(AOwner : TComponent); override;'#010+
|
|
|
- ' end;'#010+
|
|
|
- #010+
|
|
|
- ' { TValueItem }'#010+
|
|
|
- #010+
|
|
|
- ' TValueItem = Class(TObject)'#010+
|
|
|
- ' FValue : String;'#010+
|
|
|
- ' C','onstructor Create(AValue : String);'#010+
|
|
|
- ' end;'#010+
|
|
|
- #010+
|
|
|
- ' { TFunctionItem }'#010+
|
|
|
- #010+
|
|
|
- ' TFunctionItem = Class(TObject)'#010+
|
|
|
- ' FFunc : TReplaceFunction;'#010+
|
|
|
- ' Constructor Create(AFunc : TReplaceFunction);'#010+
|
|
|
- ' end;'#010+
|
|
|
- #010+
|
|
|
- '{$ifndef NO_THREADING}'#010+
|
|
|
- #010+
|
|
|
- ' { TCompileWorkerThread }'#010+
|
|
|
- #010+
|
|
|
- ' ','TCompileWorkerThread = class(TThread)'#010+
|
|
|
- ' private'#010+
|
|
|
- ' FBuildEngine: TBuildEngine;'#010+
|
|
|
- ' FCompilationOK: boolean;'#010+
|
|
|
- ' FDone: boolean;'#010+
|
|
|
- ' FErrorMessage: string;'#010+
|
|
|
- ' FNotifyMainThreadEvent: PRTLEvent;'#010+
|
|
|
- ' FNotifyStartTask: PRTLEvent;'#010+
|
|
|
- ' FPackage',': TPackage;'#010+
|
|
|
- ' protected'#010+
|
|
|
- ' procedure execute; override;'#010+
|
|
|
- ' property Done: boolean read FDone;'#010+
|
|
|
- ' property APackage: TPackage read FPackage write FPackage;'#010+
|
|
|
- ' property CompilationOK: boolean read FCompilationOK;'#010+
|
|
|
- ' property NotifyStartT','ask: PRTLEvent read FNotifyStartTask;'#010+
|
|
|
- ' property ErrorMessage: string read FErrorMessage;'#010+
|
|
|
- ' public'#010+
|
|
|
+ 'erArchive;'#013#010+
|
|
|
+ ' Property BeforeManifest : TNotifyEvent Read FBeforeManifest Write '+
|
|
|
+ 'FBeforeManifest;'#013#010+
|
|
|
+ ' Property AfterMani','fest : TNotifyEvent Read FAfterManifest Write '+
|
|
|
+ 'FAfterManifest;'#013#010+
|
|
|
+ ' Property OnLog : TLogEvent Read FOnLog Write FOnlog;'#013#010+
|
|
|
+ ' end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ ' { TCustomInstaller }'#013#010+
|
|
|
+ #013#010+
|
|
|
+ ' TCustomInstaller = Class(TComponent)'#013#010+
|
|
|
+ ' private'#013#010+
|
|
|
+ ' FBuildEngine: TBuildEngine;'#013,#010+
|
|
|
+ ' FPackages: TPackages;'#013#010+
|
|
|
+ ' FRunMode: TRunMode;'#013#010+
|
|
|
+ ' FListMode : Boolean;'#013#010+
|
|
|
+ ' FLogLevels : TVerboseLevels;'#013#010+
|
|
|
+ ' FFPMakeOptionsString: string;'#013#010+
|
|
|
+ ' FPackageVariantSettings: TStrings;'#013#010+
|
|
|
+ ' FPackageVariants: TFPList;'#013#010+
|
|
|
+ ' Protected'#013#010+
|
|
|
+ ' Pro','cedure Log(Level : TVerboseLevel; Const Msg : String);'#013#010+
|
|
|
+ ' Procedure CreatePackages; virtual;'#013#010+
|
|
|
+ ' Procedure FreePackages; virtual;'#013#010+
|
|
|
+ ' function GetPackages: TPackages; virtual;'#013#010+
|
|
|
+ ' Procedure CheckPackages; virtual;'#013#010+
|
|
|
+ ' Procedure Create','BuildEngine; virtual;'#013#010+
|
|
|
+ ' Procedure Error(const Msg : String);'#013#010+
|
|
|
+ ' Procedure Error(const Fmt : String; Args : Array of const);'#013#010+
|
|
|
+ ' Procedure AnalyzeOptions;'#013#010+
|
|
|
+ ' Procedure Usage(const FMT : String; Args : Array of const);'#013#010+
|
|
|
+ ' Procedure ','Compile(Force : Boolean); virtual;'#013#010+
|
|
|
+ ' Procedure Clean(AllTargets: boolean); virtual;'#013#010+
|
|
|
+ ' Procedure Install; virtual;'#013#010+
|
|
|
+ ' Procedure ZipInstall; virtual;'#013#010+
|
|
|
+ ' Procedure Archive; virtual;'#013#010+
|
|
|
+ ' Procedure Manifest; virtual;'#013#010+
|
|
|
+ ' Public'#013#010+
|
|
|
+ ' Co','nstructor Create(AOwner : TComponent); virtual;'#013#010+
|
|
|
+ ' Destructor destroy; override;'#013#010+
|
|
|
+ ' Function AddPackage(Const AName : String) : TPackage;'#013#010+
|
|
|
+ ' Function AddPackageVariant(AName: string; AIsInheritable: boolean'+
|
|
|
+ '): TPackageVariants;'#013#010+
|
|
|
+ ' F','unction Run : Boolean;'#013#010+
|
|
|
+ ' Property FPMakeOptionsString: string read FFPMakeOptionsString;'#013+
|
|
|
+ #010+
|
|
|
+ ' Property BuildEngine : TBuildEngine Read FBuildEngine;'#013#010+
|
|
|
+ ' //files in package'#013#010+
|
|
|
+ ' Property Packages : TPackages Read GetPackages;'#013#010+
|
|
|
+ ' Proper','ty RunMode : TRunMode Read FRunMode;'#013#010+
|
|
|
+ ' Property ListMode : Boolean Read FListMode;'#013#010+
|
|
|
+ ' end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ ' { TFPCInstaller }'#013#010+
|
|
|
+ ' TFPCInstaller = class(TCustomInstaller)'#013#010+
|
|
|
+ ' public'#013#010+
|
|
|
+ ' Constructor Create(AOwner : TComponent); override;'#013#010+
|
|
|
+ ' end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ ' {',' TBasicInstaller }'#013#010+
|
|
|
+ ' TBasicInstaller = class(TCustomInstaller)'#013#010+
|
|
|
+ ' Constructor Create(AOwner : TComponent); override;'#013#010+
|
|
|
+ ' end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ ' { TValueItem }'#013#010+
|
|
|
+ #013#010+
|
|
|
+ ' TValueItem = Class(TObject)'#013#010+
|
|
|
+ ' FValue : String;'#013#010+
|
|
|
+ ' Constructor Create(AValue : Stri','ng);'#013#010+
|
|
|
+ ' end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ ' { TFunctionItem }'#013#010+
|
|
|
+ #013#010+
|
|
|
+ ' TFunctionItem = Class(TObject)'#013#010+
|
|
|
+ ' FFunc : TReplaceFunction;'#013#010+
|
|
|
+ ' Constructor Create(AFunc : TReplaceFunction);'#013#010+
|
|
|
+ ' end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ '{$ifndef NO_THREADING}'#013#010+
|
|
|
+ #013#010+
|
|
|
+ ' { TCompileWorkerThread }'#013#010+
|
|
|
+ #013#010+
|
|
|
+ ' TCompileWorkerThr','ead = class(TThread)'#013#010+
|
|
|
+ ' private'#013#010+
|
|
|
+ ' FBuildEngine: TBuildEngine;'#013#010+
|
|
|
+ ' FCompilationOK: boolean;'#013#010+
|
|
|
+ ' FDone: boolean;'#013#010+
|
|
|
+ ' FErrorMessage: string;'#013#010+
|
|
|
+ ' FNotifyMainThreadEvent: PRTLEvent;'#013#010+
|
|
|
+ ' FNotifyStartTask: PRTLEvent;'#013#010+
|
|
|
+ ' FPackage: TPackag','e;'#013#010+
|
|
|
+ ' protected'#013#010+
|
|
|
+ ' procedure execute; override;'#013#010+
|
|
|
+ ' property Done: boolean read FDone;'#013#010+
|
|
|
+ ' property APackage: TPackage read FPackage write FPackage;'#013#010+
|
|
|
+ ' property CompilationOK: boolean read FCompilationOK;'#013#010+
|
|
|
+ ' property NotifyStartTask',': PRTLEvent read FNotifyStartTask;'#013#010+
|
|
|
+ ' property ErrorMessage: string read FErrorMessage;'#013#010+
|
|
|
+ ' public'#013#010+
|
|
|
' constructor Create(ABuildEngine: TBuildEngine; NotifyMainThreadEve'+
|
|
|
- 'nt: PRTLEvent); virtual;'#010+
|
|
|
- ' destructor Destroy; override;'#010+
|
|
|
- ' end;'#010+
|
|
|
- #010+
|
|
|
- '{$','endif NO_THREADING}'#010+
|
|
|
- #010+
|
|
|
- ' ECollectionError = Class(Exception);'#010+
|
|
|
- ' EDictionaryError = Class(Exception);'#010+
|
|
|
- ' EInstallerError = Class(Exception);'#010+
|
|
|
- #010+
|
|
|
- ' TInstallerClass = Class of TCustomInstaller;'#010+
|
|
|
- ' TDictionaryClass = Class of TDictionary;'#010+
|
|
|
- ' TPackageDi','ctionaryClass = Class of TPackageDictionary;'#010+
|
|
|
- #010+
|
|
|
- 'Type'#010+
|
|
|
+ 'nt: PRTLEvent); virtual;'#013#010+
|
|
|
+ ' destructor Destroy; override;'#013#010+
|
|
|
+ ' end;'#013#010,
|
|
|
+ #013#010+
|
|
|
+ '{$endif NO_THREADING}'#013#010+
|
|
|
+ #013#010+
|
|
|
+ ' ECollectionError = Class(Exception);'#013#010+
|
|
|
+ ' EDictionaryError = Class(Exception);'#013#010+
|
|
|
+ ' EInstallerError = Class(Exception);'#013#010+
|
|
|
+ #013#010+
|
|
|
+ ' TInstallerClass = Class of TCustomInstaller;'#013#010+
|
|
|
+ ' TDictionaryClass = Class of TDictionary;'#013#010,
|
|
|
+ ' TPackageDictionaryClass = Class of TPackageDictionary;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ 'Type'#013#010+
|
|
|
' TArchiveEvent = Procedure (Const AFileName : String; List : TStrings'+
|
|
|
- ') of Object;'#010+
|
|
|
+ ') of Object;'#013#010+
|
|
|
' TArchiveProc = Procedure (Const AFileName : String; List : TStrings)'+
|
|
|
- ';'#010+
|
|
|
- #010+
|
|
|
- 'Var'#010+
|
|
|
- ' DictionaryClass : TDictiona','ryClass = TDictionary;'#010+
|
|
|
+ ';'#013#010+
|
|
|
+ #013#010+
|
|
|
+ 'Var'#013#010+
|
|
|
+ ' Dictiona','ryClass : TDictionaryClass = TDictionary;'#013#010+
|
|
|
' PackageDictionaryClass : TPackageDictionaryClass = TPackageDictionar'+
|
|
|
- 'y;'#010+
|
|
|
- ' OnArchiveFiles : TArchiveEvent = Nil;'#010+
|
|
|
- ' ArchiveFilesProc : TArchiveProc = Nil;'#010+
|
|
|
- #010+
|
|
|
- ' Defaults : TCustomDefaults; // Set by installer.'#010+
|
|
|
- ' GlobalDic','tionary : TDictionary;'#010+
|
|
|
- #010+
|
|
|
- #010+
|
|
|
- 'Function CurrentOS : String;'#010+
|
|
|
- 'Function CurrentCPU : String;'#010+
|
|
|
- #010+
|
|
|
+ 'y;'#013#010+
|
|
|
+ ' OnArchiveFiles : TArchiveEvent = Nil;'#013#010+
|
|
|
+ ' ArchiveFilesProc : TArchiveProc = Nil;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ ' Defaults : TCustomDefaults; // Set b','y installer.'#013#010+
|
|
|
+ ' GlobalDictionary : TDictionary;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ #013#010+
|
|
|
+ 'Function CurrentOS : String;'#013#010+
|
|
|
+ 'Function CurrentCPU : String;'#013#010+
|
|
|
+ #013#010+
|
|
|
'Function Installer(InstallerClass: TInstallerClass) : TCustomInstaller'+
|
|
|
- '; overload;'#010+
|
|
|
- 'Function Installer : TCustomInstaller; overload;'#010+
|
|
|
- #010+
|
|
|
- 'Function OSToString(OS:',' TOS) : String;'#010+
|
|
|
- 'Function OSesToString(OSes: TOSes) : String;'#010+
|
|
|
- 'Function CPUToString(CPU: TCPU) : String;'#010+
|
|
|
- 'Function CPUSToString(CPUS: TCPUS) : String;'#010+
|
|
|
- 'Function StringToOS(const S : String) : TOS;'#010+
|
|
|
- 'function IsDifferentFromBuild(ACpu: TCPU; AOs: ','TOs): boolean;'#010+
|
|
|
- '//Function StringToOSes(const S : String) : TOSes;'#010+
|
|
|
- 'Function StringToCPU(const S : String) : TCPU;'#010+
|
|
|
- 'Function StringToCPUS(const S : String) : TCPUS;'#010+
|
|
|
- 'Function ModeToString(Mode: TCompilerMode) : String;'#010+
|
|
|
- 'Function StringToMode(con','st S : String) : TCompilerMode;'#010+
|
|
|
- 'Function MakeTargetString(CPU : TCPU;OS: TOS) : String;'#010+
|
|
|
+ '; overload;'#013#010+
|
|
|
+ 'Function Installer : TCustomInstaller; ov','erload;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ 'Function OSToString(OS: TOS) : String;'#013#010+
|
|
|
+ 'Function OSesToString(OSes: TOSes) : String;'#013#010+
|
|
|
+ 'Function CPUToString(CPU: TCPU) : String;'#013#010+
|
|
|
+ 'Function CPUSToString(CPUS: TCPUS) : String;'#013#010+
|
|
|
+ 'Function StringToOS(const S : String) : TOS;'#013#010+
|
|
|
+ 'function',' IsDifferentFromBuild(ACpu: TCPU; AOs: TOs): boolean;'#013#010+
|
|
|
+ '//Function StringToOSes(const S : String) : TOSes;'#013#010+
|
|
|
+ 'Function StringToCPU(const S : String) : TCPU;'#013#010+
|
|
|
+ 'Function StringToCPUS(const S : String) : TCPUS;'#013#010+
|
|
|
+ 'Function ModeToString(Mode: TCompil','erMode) : String;'#013#010+
|
|
|
+ 'Function StringToMode(const S : String) : TCompilerMode;'#013#010+
|
|
|
+ 'Function MakeTargetString(CPU : TCPU;OS: TOS) : String;'#013#010+
|
|
|
'Procedure StringToCPUOS(const S : String; Var CPU : TCPU; Var OS: TOS)'+
|
|
|
- ';'#010+
|
|
|
- 'Function FixPath (const APath : String) : String; inline; deprecated '#039+
|
|
|
- 'Use the ov','erload with AIsDir instead'#039';'#010+
|
|
|
- 'Function FixPath (const APath : String; AIsDir : Boolean) : String;'#010+
|
|
|
- 'Function IsRelativePath(const APath : String) : boolean;'#010+
|
|
|
- 'Procedure ChangeDir(const APath : String);'#010+
|
|
|
- 'Procedure SplitCommand(Const Cmd : String; ','Var Exe,Options : String)'+
|
|
|
- ';'#010+
|
|
|
+ ';'#013#010+
|
|
|
+ 'Function FixPath (const APath : S','tring) : String; inline; deprecated'+
|
|
|
+ ' '#039'Use the overload with AIsDir instead'#039';'#013#010+
|
|
|
+ 'Function FixPath (const APath : String; AIsDir : Boolean) : String;'#013+
|
|
|
+ #010+
|
|
|
+ 'Function IsRelativePath(const APath : String) : boolean;'#013#010+
|
|
|
+ 'Procedure ChangeDir(const APath : St','ring);'#013#010+
|
|
|
+ 'Procedure SplitCommand(Const Cmd : String; Var Exe,Options : String);'#013+
|
|
|
+ #010+
|
|
|
'Procedure AddCustomFpmakeCommandlineOption(const ACommandLineOption, H'+
|
|
|
- 'elpMessage : string);'#010+
|
|
|
- 'Function GetCustomFpmakeCommandlineOptionValue(const ACommandLineOptio'+
|
|
|
- 'n : string) : string;'#010+
|
|
|
- 'Function AddProgramExtension(','const ExecutableName: string; AOS : TOS'+
|
|
|
- ') : string;'#010+
|
|
|
+ 'elpMessage : string);'#013#010+
|
|
|
+ 'Function GetCustomFpmakeCommandlineOptionValue(const ACommandLineOpt','i'+
|
|
|
+ 'on : string) : string;'#013#010+
|
|
|
+ 'Function AddProgramExtension(const ExecutableName: string; AOS : TOS) '+
|
|
|
+ ': string;'#013#010+
|
|
|
'Function GetImportLibraryFilename(const UnitName: string; AOS : TOS) :'+
|
|
|
- ' string;'#010+
|
|
|
- #010+
|
|
|
- 'procedure SearchFiles(const AFileName: string; Recursive: boolean; var'+
|
|
|
- ' List: TStrings);'#010+
|
|
|
- #010+
|
|
|
- 'Implementation'#010+
|
|
|
- #010+
|
|
|
- 'uses',' typinfo, rtlconsts;'#010+
|
|
|
- #010+
|
|
|
- 'type'#010+
|
|
|
- ' TUnsortedDuplicatesStringList = class(TStringList)'#010+
|
|
|
- ' public'#010+
|
|
|
- ' function Add(const S: string): Integer; override;'#010+
|
|
|
- ' end;'#010+
|
|
|
- #010+
|
|
|
- 'var'#010+
|
|
|
- ' CustomFpmakeCommandlineOptions: TStrings;'#010+
|
|
|
- ' CustomFpMakeCommandlineValues: TStrings',';'#010+
|
|
|
- #010+
|
|
|
- '{$ifdef NO_THREADING}'#010+
|
|
|
- 'var'#010+
|
|
|
- '{$else NO_THREADING}'#010+
|
|
|
- 'threadvar'#010+
|
|
|
- '{$endif NO_THREADING}'#010+
|
|
|
- ' GPathPrefix : string;'#010+
|
|
|
- ' GLogPrefix : string;'#010+
|
|
|
- #010+
|
|
|
- 'ResourceString'#010+
|
|
|
- ' SErrInvalidCPU = '#039'Invalid CPU name "%s"'#039';'#010+
|
|
|
- ' SErrInvalidOS = '#039'Invalid OS name ','"%s"'#039';'#010+
|
|
|
- ' SErrInvalidMode = '#039'Invalid compiler mode "%s"'#039';'#010+
|
|
|
- ' SErrInvalidTarget = '#039'Invalid compiler target "%s"'#039';'#010+
|
|
|
- ' SErrNameExists = '#039'Name "%s" already exists in the collect'+
|
|
|
- 'ion.'#039';'#010+
|
|
|
- ' SErrNoSuchName = '#039'Could not find item',' with name "%s" in'+
|
|
|
- ' the collection.'#039';'#010+
|
|
|
+ ' string;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ 'procedure SearchFiles(const AFileName: string; Recur','sive: boolean; v'+
|
|
|
+ 'ar List: TStrings);'#013#010+
|
|
|
+ #013#010+
|
|
|
+ 'Implementation'#013#010+
|
|
|
+ #013#010+
|
|
|
+ 'uses typinfo, rtlconsts;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ 'type'#013#010+
|
|
|
+ ' TUnsortedDuplicatesStringList = class(TStringList)'#013#010+
|
|
|
+ ' public'#013#010+
|
|
|
+ ' function Add(const S: string): Integer; override;'#013#010+
|
|
|
+ ' end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ 'var'#013#010+
|
|
|
+ ' CustomFpmakeC','ommandlineOptions: TStrings;'#013#010+
|
|
|
+ ' CustomFpMakeCommandlineValues: TStrings;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ '{$ifdef NO_THREADING}'#013#010+
|
|
|
+ 'var'#013#010+
|
|
|
+ '{$else NO_THREADING}'#013#010+
|
|
|
+ 'threadvar'#013#010+
|
|
|
+ '{$endif NO_THREADING}'#013#010+
|
|
|
+ ' GPathPrefix : string;'#013#010+
|
|
|
+ ' GLogPrefix : string;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ 'ResourceString'#013#010+
|
|
|
+ ' SErrInvali','dCPU = '#039'Invalid CPU name "%s"'#039';'#013#010+
|
|
|
+ ' SErrInvalidOS = '#039'Invalid OS name "%s"'#039';'#013#010+
|
|
|
+ ' SErrInvalidMode = '#039'Invalid compiler mode "%s"'#039';'#013#010+
|
|
|
+ ' SErrInvalidTarget = '#039'Invalid compiler target "%s"'#039';'#013#010+
|
|
|
+ ' SErrNameExists = '#039'Name "','%s" already exists in the colle'+
|
|
|
+ 'ction.'#039';'#013#010+
|
|
|
+ ' SErrNoSuchName = '#039'Could not find item with name "%s" in t'+
|
|
|
+ 'he collection.'#039';'#013#010+
|
|
|
' SErrInValidArgument = '#039'Invalid command-line argument at positi'+
|
|
|
- 'on %d: %s'#039';'#010+
|
|
|
- ' SErrNeedArgument = '#039'Option at position %d (%s) needs an arg'+
|
|
|
- 'ument'#039';'#010+
|
|
|
- ' SErrNoPackagesDefined = '#039'No action possible: No p','ackages were '+
|
|
|
- 'defined.'#039';'#010+
|
|
|
+ 'on %d: %s'#039';'#013#010+
|
|
|
+ ' SErrNeedArgument = '#039'Option at',' position %d (%s) needs an a'+
|
|
|
+ 'rgument'#039';'#013#010+
|
|
|
+ ' SErrNoPackagesDefined = '#039'No action possible: No packages were de'+
|
|
|
+ 'fined.'#039';'#013#010+
|
|
|
' SErrInstaller = '#039'The installer encountered the following'+
|
|
|
- ' error:'#039';'#010+
|
|
|
- ' SErrDepUnknownTarget = '#039'Unknown target for unit "%s" in depende'+
|
|
|
- 'ncies for %s in package %s'#039';'#010+
|
|
|
- ' SErrExternalCommandFailed = '#039'External comma','nd "%s" failed with'+
|
|
|
- ' exit code %d. Console output:'#039'+LineEnding+'#039'%s'#039';'#010+
|
|
|
- ' SErrExtCommandNotFound= '#039'External command "%s" not found'#039';'#010+
|
|
|
- ' SErrCreatingDirectory = '#039'Failed to create directory "%s"'#039';'#010+
|
|
|
- ' SErrDeletingFile = '#039'Failed to delete file "','%s"'#039';'#010+
|
|
|
- ' SErrRemovingDirectory = '#039'Failed to remove directory "%s"'#039';'#010+
|
|
|
- ' SErrMovingFile = '#039'Failed to move file "%s" to "%s"'#039';'#010+
|
|
|
- ' SErrCopyingFile = '#039'Failed to copy file "%s" to "%s"'#039';'#010+
|
|
|
- ' SErrChangeDirFailed = '#039'Failed to enter direct','ory "%s"'#039';'#010+
|
|
|
+ ' error:'#039';'#013#010+
|
|
|
+ ' SErrDepUnknownTarget = '#039'Unknown target for un','it "%s" in depen'+
|
|
|
+ 'dencies for %s in package %s'#039';'#013#010+
|
|
|
+ ' SErrExternalCommandFailed = '#039'External command "%s" failed with e'+
|
|
|
+ 'xit code %d. Console output:'#039'+LineEnding+'#039'%s'#039';'#013#010+
|
|
|
+ ' SErrExtCommandNotFound= '#039'External command "%s" not found'#039';'#013+
|
|
|
+ #010+
|
|
|
+ ' SErrCreatingDi','rectory = '#039'Failed to create directory "%s"'#039';'+
|
|
|
+ #013#010+
|
|
|
+ ' SErrDeletingFile = '#039'Failed to delete file "%s"'#039';'#013#010+
|
|
|
+ ' SErrRemovingDirectory = '#039'Failed to remove directory "%s"'#039';'#013+
|
|
|
+ #010+
|
|
|
+ ' SErrMovingFile = '#039'Failed to move file "%s" to "%s"'#039';'#013+
|
|
|
+ #010+
|
|
|
+ ' SErrCopyin','gFile = '#039'Failed to copy file "%s" to "%s"'#039';'+
|
|
|
+ #013#010+
|
|
|
+ ' SErrChangeDirFailed = '#039'Failed to enter directory "%s"'#039';'#013+
|
|
|
+ #010+
|
|
|
' SErrInvalidArgumentToSubstitute = '#039'Invalid number of arguments t'+
|
|
|
- 'o Substitute'#039';'#010+
|
|
|
- ' SErrNoArchiveSupport = '#039'This binary contains no archive support'+
|
|
|
- '. Please recompile with archive support'#039';'#010+
|
|
|
- ' SErrNoDictionaryItem = '#039'No item calle','d "%s" in the dictionary'+
|
|
|
- #039';'#010+
|
|
|
+ 'o Substitute'#039';'#013#010+
|
|
|
+ ' SErrNoArchiveSupport = '#039'This binary contain','s no archive suppo'+
|
|
|
+ 'rt. Please recompile with archive support'#039';'#013#010+
|
|
|
+ ' SErrNoDictionaryItem = '#039'No item called "%s" in the dictionary'#039+
|
|
|
+ ';'#013#010+
|
|
|
' SErrNoDictionaryValue = '#039'The item "%s" in the dictionary is not '+
|
|
|
- 'a value'#039';'#010+
|
|
|
- ' SErrNoDictionaryFunc = '#039'The item "%s" in the dictionary is not '+
|
|
|
- 'a function'#039';'#010+
|
|
|
- ' SErrInvalidFPCInfo = '#039'Compiler returns invalid inform','ation,'+
|
|
|
- ' check if fpc -iV works'#039';'#010+
|
|
|
+ 'a value'#039';'#013#010+
|
|
|
+ ' SErrNoDictionaryFunc = '#039'The i','tem "%s" in the dictionary is no'+
|
|
|
+ 't a function'#039';'#013#010+
|
|
|
+ ' SErrInvalidFPCInfo = '#039'Compiler returns invalid information, c'+
|
|
|
+ 'heck if fpc -iV works'#039';'#013#010+
|
|
|
' SErrDependencyNotFound = '#039'Could not find unit directory for depe'+
|
|
|
- 'ndency package "%s"'#039';'#010+
|
|
|
- ' SErrAlreadyInitialized = '#039'Installer can only be initialized once'+
|
|
|
- #039';'#010+
|
|
|
- ' SErrInvalidState = '#039'Invalid state for target',' %s'#039';'#010+
|
|
|
+ 'ndency package "%s"'#039';'#013#010+
|
|
|
+ ' SErrAlread','yInitialized = '#039'Installer can only be initialized on'+
|
|
|
+ 'ce'#039';'#013#010+
|
|
|
+ ' SErrInvalidState = '#039'Invalid state for target %s'#039';'#013#010+
|
|
|
' SErrCouldNotCompile = '#039'Could not compile target %s from packag'+
|
|
|
- 'e %s'#039';'#010+
|
|
|
- ' SErrUnsupportedBuildmode = '#039'Package does not support this buildm'+
|
|
|
- 'ode'#039';'#010+
|
|
|
+ 'e %s'#039';'#013#010+
|
|
|
+ ' SErrUnsupportedBuildmode = '#039'Package does not sup','port this buil'+
|
|
|
+ 'dmode'#039';'#013#010+
|
|
|
' SErrPackVarNotExist = '#039'There is no package variant with the na'+
|
|
|
- 'me "%s"'#039';'#010+
|
|
|
- #010+
|
|
|
- ' SWarnCircu','larTargetDependency = '#039'Warning: Circular dependency '+
|
|
|
- 'detected when compiling target %s with target %s'#039';'#010+
|
|
|
- ' SWarnCircularPackageDependency = '#039'Warning: Circular dependency d'+
|
|
|
- 'etected when compiling package %s with package %s'#039';'#010+
|
|
|
- ' SWarnFailedToSetT','ime = '#039'Warning: Failed to set timestamp on'+
|
|
|
- ' file "%s"'#039';'#010+
|
|
|
- ' SWarnFailedToGetTime = '#039'Warning: Failed to get timestamp from'+
|
|
|
- ' file "%s"'#039';'#010+
|
|
|
+ 'me "%s"'#039';'#013#010+
|
|
|
+ #013#010+
|
|
|
+ ' SWarnCircularTargetDependency = '#039'Warning: Circular dependency de'+
|
|
|
+ 'tected when compiling target %s with target %s'#039';'#013#010+
|
|
|
+ ' SWarnCircularPackage','Dependency = '#039'Warning: Circular dependency'+
|
|
|
+ ' detected when compiling package %s with package %s'#039';'#013#010+
|
|
|
+ ' SWarnFailedToSetTime = '#039'Warning: Failed to set timestamp on f'+
|
|
|
+ 'ile "%s"'#039';'#013#010+
|
|
|
+ ' SWarnFailedToGetTime = '#039'Warning: Failed to get timestamp fro',
|
|
|
+ 'm file "%s"'#039';'#013#010+
|
|
|
' SWarnAttemptingToCompileNonNeutralTarget = '#039'Warning: Attempting '+
|
|
|
- 'to compile non-neutral target %s'#039';'#010+
|
|
|
- ' ','SWarnSourceFileNotFound = '#039'Warning: Source file "%s" from pac'+
|
|
|
- 'kage %s not found for %s'#039';'#010+
|
|
|
- ' SWarnIncludeFileNotFound = '#039'Warning: Include file "%s" from pack'+
|
|
|
- 'age %s not found for %s'#039';'#010+
|
|
|
- ' SWarnDepUnitNotFound = '#039'Warning: Dependency on unit %','s is '+
|
|
|
- 'not supported for %s'#039';'#010+
|
|
|
+ 'to compile non-neutral target %s'#039';'#013#010+
|
|
|
+ ' SWarnSourceFileNotFound = '#039'Warning: Source file "%s" from packa'+
|
|
|
+ 'ge %s not found for %s'#039';'#013#010+
|
|
|
+ ' SWarnIncludeFileNotFound = '#039'W','arning: Include file "%s" from pa'+
|
|
|
+ 'ckage %s not found for %s'#039';'#013#010+
|
|
|
+ ' SWarnDepUnitNotFound = '#039'Warning: Dependency on unit %s is no'+
|
|
|
+ 't supported for %s'#039';'#013#010+
|
|
|
' SWarnTargetDependsOnPackage = '#039'Warning: Target %s of package %s '+
|
|
|
- 'depends on another package (%s). These kind of dependencies are not pr'+
|
|
|
- 'ocessed'#039';'#010+
|
|
|
- ' SWarnDependOnOtherPlatformPackage = '#039'Warning: Package %s depends',
|
|
|
- ' on package %s which is not available for the %s platform'#039';'#010+
|
|
|
- ' SWarnStartCompilingPackage = '#039'Start compiling package %s for tar'+
|
|
|
- 'get %s.'#039';'#010+
|
|
|
+ 'depends on another packa','ge (%s). These kind of dependencies are not '+
|
|
|
+ 'processed'#039';'#013#010+
|
|
|
+ ' SWarnDependOnOtherPlatformPackage = '#039'Warning: Package %s depends'+
|
|
|
+ ' on package %s which is not available for the %s platform'#039';'#013#010+
|
|
|
+ ' SWarnStartCompilingPackage = '#039'Start compiling package ','%s for t'+
|
|
|
+ 'arget %s.'#039';'#013#010+
|
|
|
' SWarnCompilingPackagecompleteProgress = '#039'[%3.0f%%] Compiled pack'+
|
|
|
- 'age %s'#039';'#010+
|
|
|
- ' SWarnCompilingPackagecomple','te = '#039'Compiled package %s'#039';'#010+
|
|
|
+ 'age %s'#039';'#013#010+
|
|
|
+ ' SWarnCompilingPackagecomplete = '#039'Compiled package %s'#039';'#013#010+
|
|
|
' SWarnSkipPackageTargetProgress = '#039'[%3.0f%%] Skipped package %s w'+
|
|
|
- 'hich has been disabled for target %s'#039';'#010+
|
|
|
+ 'hich has been disab','led for target %s'#039';'#013#010+
|
|
|
' SWarnSkipPackageTarget = '#039'Skipped package %s which has been disa'+
|
|
|
- 'bled for target %s'#039';'#010+
|
|
|
- ' SWarnInstallationP','ackagecomplete = '#039'Installation package %s fo'+
|
|
|
- 'r target %s succeeded'#039';'#010+
|
|
|
- ' SWarnCleanPackagecomplete = '#039'Clean of package %s completed'#039';'+
|
|
|
- #010+
|
|
|
+ 'bled for target %s'#039';'#013#010+
|
|
|
+ ' SWarnInstallationPackagecomplete = '#039'Installation package %s for '+
|
|
|
+ 'target %s succeeded'#039';'#013#010+
|
|
|
+ ' SWarnCleanPackagecomplete = '#039'Clean of pa','ckage %s completed'#039+
|
|
|
+ ';'#013#010+
|
|
|
' SWarnCanNotGetAccessRights = '#039'Warning: Failed to copy access-rig'+
|
|
|
- 'hts from file %s'#039';'#010+
|
|
|
- ' SWarnCanNotSetAccessRi','ghts = '#039'Warning: Failed to copy access-r'+
|
|
|
- 'ights to file %s'#039';'#010+
|
|
|
- ' SWarnCanNotGetFileAge = '#039'Warning: Failed to get FileAge for %s'#039+
|
|
|
- ';'#010+
|
|
|
+ 'hts from file %s'#039';'#013#010+
|
|
|
+ ' SWarnCanNotSetAccessRights = '#039'Warning: Failed to copy access-rig'+
|
|
|
+ 'hts to file %s'#039';'#013#010+
|
|
|
+ ' SWarnCanNotGetFileAge = '#039'Warning: Failed to ge','t FileAge for %s'+
|
|
|
+ #039';'#013#010+
|
|
|
' SWarnExtCommandNotFound = '#039'Warning: External command "%s" not fo'+
|
|
|
- 'und but "%s" is older then "%s"'#039';'#010+
|
|
|
- ' SWarnDuplica','tePackage = '#039'Warning: Package %s is already added.'+
|
|
|
- ' Using the existing package'#039';'#010+
|
|
|
- #010+
|
|
|
- ' SInfoPackageAlreadyProcessed = '#039'Package %s is already processed'#039+
|
|
|
- ';'#010+
|
|
|
- ' SInfoCompilingTarget = '#039'Compiling target %s'#039';'#010+
|
|
|
- ' SInfoExecutingCommand = '#039'Executing c','ommand "%s %s"'#039';'#010+
|
|
|
- ' SInfoCreatingOutputDir = '#039'Creating output dir "%s"'#039';'#010+
|
|
|
- ' SInfoInstallingPackage = '#039'Installing package %s'#039';'#010+
|
|
|
- ' SInfoArchivingPackage = '#039'Archiving package %s in "%s"'#039';'#010+
|
|
|
- ' SInfoCleaningPackage = '#039'Cleaning package %s'#039';'#010+
|
|
|
- ' S','InfoManifestPackage = '#039'Creating manifest for package %s'#039+
|
|
|
- ';'#010+
|
|
|
- ' SInfoCopyingFile = '#039'Copying file "%s" to "%s"'#039';'#010+
|
|
|
- ' SInfoDeletingFile = '#039'Deleting file "%s"'#039';'#010+
|
|
|
+ 'und but "%s" is older then "%s"'#039';'#013#010+
|
|
|
+ ' SWarnDuplicatePackage = '#039'Warning: Package %s is already added. U'+
|
|
|
+ 'sing the existing package'#039';'#013#010+
|
|
|
+ #013#010+
|
|
|
+ ' SInfoPackageAlreadyP','rocessed = '#039'Package %s is already processe'+
|
|
|
+ 'd'#039';'#013#010+
|
|
|
+ ' SInfoCompilingTarget = '#039'Compiling target %s'#039';'#013#010+
|
|
|
+ ' SInfoExecutingCommand = '#039'Executing command "%s %s"'#039';'#013#010+
|
|
|
+ ' SInfoCreatingOutputDir = '#039'Creating output dir "%s"'#039';'#013#010+
|
|
|
+ ' SInfoInstallingPackage ','= '#039'Installing package %s'#039';'#013#010+
|
|
|
+ ' SInfoArchivingPackage = '#039'Archiving package %s in "%s"'#039';'#013+
|
|
|
+ #010+
|
|
|
+ ' SInfoCleaningPackage = '#039'Cleaning package %s'#039';'#013#010+
|
|
|
+ ' SInfoManifestPackage = '#039'Creating manifest for package %s'#039';'+
|
|
|
+ #013#010+
|
|
|
+ ' SInfoCopyingFile = '#039'Copyi','ng file "%s" to "%s"'#039';'#013+
|
|
|
+ #010+
|
|
|
+ ' SInfoDeletingFile = '#039'Deleting file "%s"'#039';'#013#010+
|
|
|
' SInfoSourceNewerDest = '#039'Source file "%s" (%s) is newer than d'+
|
|
|
- 'estina','tion "%s" (%s).'#039';'#010+
|
|
|
+ 'estination "%s" (%s).'#039';'#013#010+
|
|
|
' SInfoDestDoesNotExist = '#039'Destination file "%s" does not exist.'+
|
|
|
- #039';'#010+
|
|
|
- ' SInfoFallbackBuildmode = '#039'Buildmode not supported by package, f'+
|
|
|
- 'alling back to one by one unit compilation'#039';'#010+
|
|
|
- ' SInfoFallbackBuildmodeBU= '#039'Buildmode not',' supported by package,'+
|
|
|
- ' falling back to compilation using a buildunit'#039';'#010+
|
|
|
- #010+
|
|
|
- ' SDbgComparingFileTimes = '#039'Comparing file "%s" time "%s" to "%'+
|
|
|
- 's" time "%s".'#039';'#010+
|
|
|
+ #039';'#013#010+
|
|
|
+ ' SI','nfoFallbackBuildmode = '#039'Buildmode not supported by package,'+
|
|
|
+ ' falling back to one by one unit compilation'#039';'#013#010+
|
|
|
+ ' SInfoFallbackBuildmodeBU= '#039'Buildmode not supported by package, f'+
|
|
|
+ 'alling back to compilation using a buildunit'#039';'#013#010+
|
|
|
+ #013#010+
|
|
|
+ ' SDbgComparingF','ileTimes = '#039'Comparing file "%s" time "%s" to '+
|
|
|
+ '"%s" time "%s".'#039';'#013#010+
|
|
|
' SDbgCompilingDependenciesOfTarget = '#039'Compiling dependencies of t'+
|
|
|
- 'arget %s'#039';'#010+
|
|
|
- ' SDbgRes','olvingSourcesOfTarget = '#039'Resolving filenames of target '+
|
|
|
- '%s for %s'#039';'#010+
|
|
|
- ' SDbgResolvedSourceFile = '#039'Resolved source file %s to "%s"'#039+
|
|
|
- ';'#010+
|
|
|
+ 'arget %s'#039';'#013#010+
|
|
|
+ ' SDbgResolvingSourcesOfTarget = '#039'Resolving filenames of target %s'+
|
|
|
+ ' for %s'#039';'#013#010+
|
|
|
+ ' SDbgResolvedSour','ceFile = '#039'Resolved source file %s to "%s"'#039+
|
|
|
+ ';'#013#010+
|
|
|
' SDbgSourceAlreadyResolved = '#039'Source file of %s has been resolved'+
|
|
|
- ' earlier'#039';'#010+
|
|
|
- ' SDbgResolvedIncludeFile = '#039,'Resolved include file %s to "%s"'#039+
|
|
|
- ';'#010+
|
|
|
- ' SDbgOutputNotYetAvailable = '#039'Output file %s not available'#039';'#010+
|
|
|
- ' SDbgDependencyOnUnit = '#039'Dependency of %s on unit %s'#039';'#010+
|
|
|
+ ' earlier'#039';'#013#010+
|
|
|
+ ' SDbgResolvedIncludeFile = '#039'Resolved include file %s to "%s"'#039+
|
|
|
+ ';'#013#010+
|
|
|
+ ' SDbgOutputNotYetAvailable = '#039'Output file %s n','ot available'#039';'+
|
|
|
+ #013#010+
|
|
|
+ ' SDbgDependencyOnUnit = '#039'Dependency of %s on unit %s'#039';'#013+
|
|
|
+ #010+
|
|
|
' SDbgDependencyUnitRecompiled = '#039'Dependent unit %s is being recom'+
|
|
|
- 'piled'#039';'#010+
|
|
|
- ' SDbgMu','stCompile = '#039'Must compile %s. (%s)'#039';'#010+
|
|
|
- ' SDbgSkippingTargetWrongCPU = '#039'Skipping target %s, different CPU '+
|
|
|
- '(%s)'#039';'#010+
|
|
|
+ 'piled'#039';'#013#010+
|
|
|
+ ' SDbgMustCompile = '#039'Must compile %s. (%s)'#039';'#013#010+
|
|
|
+ ' SDbgSkippingTargetWrongCPU = ',#039'Skipping target %s, different CPU '+
|
|
|
+ '(%s)'#039';'#013#010+
|
|
|
' SDbgSkippingTargetWrongOS = '#039'Skipping target %s, different OS ('+
|
|
|
- '%s)'#039';'#010+
|
|
|
- ' SDbgTargetIsNotAUnitOrProgram = '#039'Skipping Targ','et %s, not an un'+
|
|
|
- 'it or program'#039';'#010+
|
|
|
- ' SDbgConsideringTarget = '#039'Considering target %s'#039';'#010+
|
|
|
- ' SDbgConsideringPackage = '#039'Considering package %s'#039';'#010+
|
|
|
+ '%s)'#039';'#013#010+
|
|
|
+ ' SDbgTargetIsNotAUnitOrProgram = '#039'Skipping Target %s, not an unit'+
|
|
|
+ ' or program'#039';'#013#010+
|
|
|
+ ' SDbgConsideringTarget = '#039'Considering ','target %s'#039';'#013#010+
|
|
|
+ ' SDbgConsideringPackage = '#039'Considering package %s'#039';'#013#010+
|
|
|
' SDbgExternalDependency = '#039'External dependency %s found in "%s'+
|
|
|
- '"'#039';'#010+
|
|
|
- ' SDbgBuildEngineArchiving ',' = '#039'Build engine archiving'#039';'#010+
|
|
|
- ' SDbgBuildEngineGenerateManifests = '#039'Build engine generating mani'+
|
|
|
- 'fests'#039';'#010+
|
|
|
- ' SDbgBuildEngineCleaning = '#039'Build engine cleaning'#039';'#010+
|
|
|
- ' SDbgGenerating = '#039'Generating "%s"'#039';'#010+
|
|
|
- ' SDbgLoading = '#039'Lo','ading "%s"'#039';'#010+
|
|
|
- ' SDbgFound = '#039'Found'#039';'#010+
|
|
|
- ' SDbgNotFound = '#039'Not Found'#039';'#010+
|
|
|
- ' SDbgDirectoryExists = '#039'Directory "%s" %s'#039';'#010+
|
|
|
- ' SDbgFileExists = '#039'File "%s" %s'#039';'#010+
|
|
|
- ' SDbgArchivingFile = '#039'Archiving "%s"'#039';'#010,
|
|
|
- ' SDbgSearchPath = '#039'Using %s path "%s"'#039';'#010+
|
|
|
- ' SDbgEnterDir = '#039'Entering directory "%s"'#039';'#010+
|
|
|
+ '"'#039';'#013#010+
|
|
|
+ ' SDbgBuildEngineArchiving = '#039'Build engine archiving'#039';'#013#010+
|
|
|
+ ' SDbgBuildEngineGenerateManifests = '#039'Buil','d engine generating ma'+
|
|
|
+ 'nifests'#039';'#013#010+
|
|
|
+ ' SDbgBuildEngineCleaning = '#039'Build engine cleaning'#039';'#013#010+
|
|
|
+ ' SDbgGenerating = '#039'Generating "%s"'#039';'#013#010+
|
|
|
+ ' SDbgLoading = '#039'Loading "%s"'#039';'#013#010+
|
|
|
+ ' SDbgFound = '#039'Found'#039';'#013#010+
|
|
|
+ ' SDbgNotFound',' = '#039'Not Found'#039';'#013#010+
|
|
|
+ ' SDbgDirectoryExists = '#039'Directory "%s" %s'#039';'#013#010+
|
|
|
+ ' SDbgFileExists = '#039'File "%s" %s'#039';'#013#010+
|
|
|
+ ' SDbgArchivingFile = '#039'Archiving "%s"'#039';'#013#010+
|
|
|
+ ' SDbgSearchPath = '#039'Using %s path "%s"'#039';'#013#010+
|
|
|
+ ' SDbgEnt','erDir = '#039'Entering directory "%s"'#039';'#013+
|
|
|
+ #010+
|
|
|
' SDbgPackageChecksumChanged = '#039'Dependent package %s is modified'#039+
|
|
|
- ';'#010+
|
|
|
- ' SDbgFileDoesNotExist = '#039'File "%s" does not exist'#039';'#010+
|
|
|
- ' SDbg','DirectoryDoesNotExist = '#039'Directory "%s" does not exist'#039+
|
|
|
- ';'#010+
|
|
|
+ ';'#013#010+
|
|
|
+ ' SDbgFileDoesNotExist = '#039'File "%s" does not exist'#039';'#013#010+
|
|
|
+ ' SDbgDirectoryDoesNotExist = '#039'Directory "%s" does not exist'#039';'+
|
|
|
+ #013#010,
|
|
|
' SDbgDirectoryNotEmpty = '#039'Directory "%s" is not empty. Will n'+
|
|
|
- 'ot remove'#039';'#010+
|
|
|
- ' SDbgGenerateBuildUnit = '#039'Generate build-unit %s'#039';'#010+
|
|
|
- ' SDbgForcedCompile = '#039'Forced compile'#039';'#010+
|
|
|
- ' ',' SDbgOutputDoesNotExist = '#039'Output file does not exist'#039';'#010+
|
|
|
+ 'ot remove'#039';'#013#010+
|
|
|
+ ' SDbgGenerateBuildUnit = '#039'Generate build-unit %s'#039';'#013#010+
|
|
|
+ ' SDbgForcedCompile = '#039'Forced compile'#039';'#013#010+
|
|
|
+ ' SDbgOutputDoesNotExist = '#039'Output file does not exi','st'#039';'#013+
|
|
|
+ #010+
|
|
|
' SDbgNewerSource = '#039'Source file is newer then output fi'+
|
|
|
- 'le'#039';'#010+
|
|
|
+ 'le'#039';'#013#010+
|
|
|
' SDbgNewerInclude = '#039'The include file %s is newer then o'+
|
|
|
- 'utput file'#039';'#010+
|
|
|
- ' SDbgDependencyRecompiled = '#039,'The unit %s where this unit depend'+
|
|
|
- 's on is recompiled'#039';'#010+
|
|
|
+ 'utput file'#039';'#013#010+
|
|
|
+ ' SDbgDependencyRecompiled = '#039'The unit %s where this unit depends'+
|
|
|
+ ' on is recompile','d'#039';'#013#010+
|
|
|
' SDbgPackageDepRecompiled = '#039'The package %s where this package d'+
|
|
|
- 'epends on is recompiled'#039';'#010+
|
|
|
+ 'epends on is recompiled'#039';'#013#010+
|
|
|
' SDbgTargetHasToBeCompiled = '#039'At least one of the targets in the '+
|
|
|
- 'package has to be compiled.',#039';'#010+
|
|
|
- #010+
|
|
|
- ' // Help messages for usage'#010+
|
|
|
- ' SValue = '#039'Value'#039';'#010+
|
|
|
- ' SHelpUsage = '#039'Usage: %s command [options]'#039';'#010+
|
|
|
+ 'package has to be compiled.'#039';'#013#010+
|
|
|
+ #013#010+
|
|
|
+ ' // Help messages for usage'#013#010+
|
|
|
+ ' SValue ',' = '#039'Value'#039';'#013#010+
|
|
|
+ ' SHelpUsage = '#039'Usage: %s command [options]'#039';'#013#010+
|
|
|
' SHelpCommand = '#039'Where command is one of the following:'#039+
|
|
|
- ';'#010+
|
|
|
- ' SHelpCompile = '#039'Compile all units in the pac','kage(s).'#039+
|
|
|
- ';'#010+
|
|
|
- ' SHelpBuild = '#039'Build all units in the package(s).'#039';'#010+
|
|
|
+ ';'#013#010+
|
|
|
+ ' SHelpCompile = '#039'Compile all units in the package(s).'#039';'+
|
|
|
+ #013#010+
|
|
|
+ ' SHelpBuild = '#039'Build ','all units in the package(s).'#039';'+
|
|
|
+ #013#010+
|
|
|
' SHelpInstall = '#039'Install all units in the package(s).'#039';'+
|
|
|
- #010+
|
|
|
+ #013#010+
|
|
|
' SHelpClean = '#039'Clean (remove) all units in the package(s'+
|
|
|
- ').'#039';'#010+
|
|
|
- ' SHelpArchive = '#039'Create ','archive (zip) with all units in '+
|
|
|
- 'the package(s).'#039';'#010+
|
|
|
- ' SHelpHelp = '#039'This message.'#039';'#010+
|
|
|
+ ').'#039';'#013#010+
|
|
|
+ ' SHelpArchive = '#039'Create archive (zip) with all units in th'+
|
|
|
+ 'e pac','kage(s).'#039';'#013#010+
|
|
|
+ ' SHelpHelp = '#039'This message.'#039';'#013#010+
|
|
|
' SHelpManifest = '#039'Create a manifest suitable for import in '+
|
|
|
- 'repository.'#039';'#010+
|
|
|
+ 'repository.'#039';'#013#010+
|
|
|
' SHelpCmdOptions = '#039'Where options is one or more of the follo'+
|
|
|
- 'win','g:'#039';'#010+
|
|
|
- ' SHelpCPU = '#039'Compile for indicated CPU.'#039';'#010+
|
|
|
- ' SHelpOS = '#039'Compile for indicated OS'#039';'#010+
|
|
|
- ' SHelpTarget = '#039'Compile for indicated target'#039';'#010+
|
|
|
+ 'wing:'#039';'#013#010+
|
|
|
+ ' SHelpCPU = '#039'Compi','le for indicated CPU.'#039';'#013#010+
|
|
|
+ ' SHelpOS = '#039'Compile for indicated OS'#039';'#013#010+
|
|
|
+ ' SHelpTarget = '#039'Compile for indicated target'#039';'#013#010+
|
|
|
' SHelpList = '#039'list commands instead of actually executi'+
|
|
|
- 'ng them','.'#039';'#010+
|
|
|
- ' SHelpPrefix = '#039'Use indicated prefix directory for all co'+
|
|
|
- 'mmands.'#039';'#010+
|
|
|
- ' SHelpNoFPCCfg = '#039'Compiler will not use fpc.cfg'#039';'#010+
|
|
|
+ 'ng them.'#039';'#013#010+
|
|
|
+ ' SHelpPrefix = '#039'Us','e indicated prefix directory for all '+
|
|
|
+ 'commands.'#039';'#013#010+
|
|
|
+ ' SHelpNoFPCCfg = '#039'Compiler will not use fpc.cfg'#039';'#013#010+
|
|
|
' SHelpBaseInstallDir = '#039'Use indicated directory as base install d'+
|
|
|
- 'ir.'#039';'#010+
|
|
|
- ' SHelpLocalUnitDir = '#039'Use in','dicated directory as local (user)'+
|
|
|
- ' unit dir.'#039';'#010+
|
|
|
+ 'ir.'#039';'#013#010+
|
|
|
+ ' SHelpLocalUnitDir = '#039'Use indicated directory as local (','user)'+
|
|
|
+ ' unit dir.'#039';'#013#010+
|
|
|
' SHelpGlobalUnitDir = '#039'Use indicated directory as global unit di'+
|
|
|
- 'r.'#039';'#010+
|
|
|
+ 'r.'#039';'#013#010+
|
|
|
' SHelpUnitInstallDir = '#039'Use indicated directory to install units '+
|
|
|
- 'into.'#039';'#010+
|
|
|
- ' SHelpCompiler = '#039'Use indicated binary as ','compiler'#039';'#010+
|
|
|
- ' SHelpConfig = '#039'Use indicated config file when compiling.'+
|
|
|
- #039';'#010+
|
|
|
+ 'into.'#039';'#013#010+
|
|
|
+ ' SHelpCompiler = '#039'Use indicated binary as compiler'#039';'#013+
|
|
|
+ #010+
|
|
|
+ ' SHelpConfig',' = '#039'Use indicated config file when compilin'+
|
|
|
+ 'g.'#039';'#013#010+
|
|
|
' SHelpOptions = '#039'Pass extra options to the compiler.'#039';'+
|
|
|
+ #013#010+
|
|
|
+ ' SHelpVerbose = '#039'Be verbose when working.'#039';'#013#010+
|
|
|
+ ' SHelpInstExamples = '#039'Install the example-sources.'#039';'#013#010+
|
|
|
+ ' SHelpSk','ipCrossProgs = '#039'Skip programs when cross-compiling/inst'+
|
|
|
+ 'alling'#039';'#013#010+
|
|
|
+ ' SHelpIgnoreInvOpt = '#039'Ignore further invalid options.'#039';'#013+
|
|
|
#010+
|
|
|
- ' SHelpVerbose = '#039'Be verbose when working.'#039';'#010+
|
|
|
- ' SHelpInstExamples = '#039'Install the example-','sources.'#039';'#010+
|
|
|
- ' SHelpSkipCrossProgs = '#039'Skip programs when cross-compiling/instal'+
|
|
|
- 'ling'#039';'#010+
|
|
|
- ' SHelpIgnoreInvOpt = '#039'Ignore further invalid options.'#039';'#010+
|
|
|
' sHelpFpdocOutputDir = '#039'Use indicated directory as fpdoc output f'+
|
|
|
- 'older.'#039';'#010+
|
|
|
- ' sHelpThreads ','= '#039'Enable the indicated amount of worker t'+
|
|
|
- 'hreads.'#039';'#010+
|
|
|
+ 'older.'#039';'#013#010+
|
|
|
+ ' sHelpThreads = '#039'Enable the ind','icated amount of worker t'+
|
|
|
+ 'hreads.'#039';'#013#010+
|
|
|
' sHelpUseEnvironment = '#039'Use environment to pass options to compil'+
|
|
|
- 'er.'#039';'#010+
|
|
|
+ 'er.'#039';'#013#010+
|
|
|
' SHelpUseBuildUnit = '#039'Compile package in Build-unit mode.'#039';'+
|
|
|
- #010+
|
|
|
- #010+
|
|
|
- #010+
|
|
|
- 'Const'#010+
|
|
|
- ' // Keys for Defaults file. Do not localize.',#010+
|
|
|
- ' KeyCompiler = '#039'Compiler'#039';'#010+
|
|
|
- ' KeyArchive = '#039'Archive'#039';'#010+
|
|
|
- ' KeyCopy = '#039'Copy'#039';'#010+
|
|
|
- ' KeyMkDir = '#039'MkDir'#039';'#010+
|
|
|
- ' KeyMove = '#039'Move'#039';'#010+
|
|
|
- ' KeyRemove = '#039'Remove'#039';'#010+
|
|
|
- ' KeyRemoveDir= '#039'RemoveDir'#039';'#010+
|
|
|
- ' KeyRemoveTree= '#039'RemoveTree'#039';'#010+
|
|
|
- ' KeyOptions = '#039'Options'#039,';'#010+
|
|
|
- ' KeyCPU = '#039'CPU'#039';'#010+
|
|
|
- ' KeyOS = '#039'OS'#039';'#010+
|
|
|
- ' KeyMode = '#039'Mode'#039';'#010+
|
|
|
- ' KeyPrefix = '#039'Prefix'#039';'#010+
|
|
|
- ' KeyTarget = '#039'Target'#039';'#010+
|
|
|
- ' KeyNoFPCCfg = '#039'NoFPCCfg'#039';'#010+
|
|
|
- ' KeyUseEnv = '#039'UseEnv'#039';'#010+
|
|
|
- ' KeyLocalUnitDir = '#039'LocalUnitDir'#039';'#010+
|
|
|
- ' KeyGlobalUnitDir ',' = '#039'GlobalUnitDir'#039';'#010+
|
|
|
- ' KeyBaseInstallDir = '#039'BaseInstallDir'#039';'#010+
|
|
|
- ' KeyUnitInstallDir = '#039'UnitInstallDir'#039';'#010+
|
|
|
- ' KeyBinInstallDir = '#039'BinInstallDir'#039';'#010+
|
|
|
- ' KeyDocInstallDir = '#039'DocInstallDir'#039';'#010+
|
|
|
- ' KeyExamplesInstallDir = '#039'ExamplesInstallDi','r'#039';'#010+
|
|
|
- ' KeyInstallExamples = '#039'InstallExamples'#039';'#010+
|
|
|
- ' KeySkipCrossProdrams = '#039'SkipCrossPrograms'#039';'#010+
|
|
|
- ' // Keys for unit config'#010+
|
|
|
- ' KeyName = '#039'Name'#039';'#010+
|
|
|
- ' KeyVersion = '#039'Version'#039';'#010+
|
|
|
- ' KeyChecksum = '#039'Checksum'#039';'#010+
|
|
|
- ' KeyNeedLibC = '#039'NeedLibC'#039';'#010+
|
|
|
- ' KeyDepend','s = '#039'Depends'#039';'#010+
|
|
|
- ' KeyFlags = '#039'Flags'#039';'#010+
|
|
|
- ' KeyAddIn = '#039'FPMakeAddIn'#039';'#010+
|
|
|
- ' KeySourcePath = '#039'SourcePath'#039';'#010+
|
|
|
- ' KeyFPMakeOptions = '#039'FPMakeOptions'#039';'#010+
|
|
|
- ' KeyPackageVar = '#039'PackageVariant_'#039';'#010+
|
|
|
- #010+
|
|
|
- '{***********************************************************','********'+
|
|
|
- '*********'#010+
|
|
|
- ' Helpers'#010+
|
|
|
+ #013#010+
|
|
|
+ #013#010+
|
|
|
+ #013#010+
|
|
|
+ 'Const'#013#010+
|
|
|
+ ' // Keys for Defaults file. Do not localize.'#013#010+
|
|
|
+ ' KeyComp','iler = '#039'Compiler'#039';'#013#010+
|
|
|
+ ' KeyArchive = '#039'Archive'#039';'#013#010+
|
|
|
+ ' KeyCopy = '#039'Copy'#039';'#013#010+
|
|
|
+ ' KeyMkDir = '#039'MkDir'#039';'#013#010+
|
|
|
+ ' KeyMove = '#039'Move'#039';'#013#010+
|
|
|
+ ' KeyRemove = '#039'Remove'#039';'#013#010+
|
|
|
+ ' KeyRemoveDir= '#039'RemoveDir'#039';'#013#010+
|
|
|
+ ' KeyRemoveTree= '#039'RemoveTree'#039';'#013#010+
|
|
|
+ ' KeyOptions = '#039'Options'#039';'#013,#010+
|
|
|
+ ' KeyCPU = '#039'CPU'#039';'#013#010+
|
|
|
+ ' KeyOS = '#039'OS'#039';'#013#010+
|
|
|
+ ' KeyMode = '#039'Mode'#039';'#013#010+
|
|
|
+ ' KeyPrefix = '#039'Prefix'#039';'#013#010+
|
|
|
+ ' KeyTarget = '#039'Target'#039';'#013#010+
|
|
|
+ ' KeyNoFPCCfg = '#039'NoFPCCfg'#039';'#013#010+
|
|
|
+ ' KeyUseEnv = '#039'UseEnv'#039';'#013#010+
|
|
|
+ ' KeyLocalUnitDir = '#039'LocalUnitDir'#039';'#013#010+
|
|
|
+ ' KeyGlobalUni','tDir = '#039'GlobalUnitDir'#039';'#013#010+
|
|
|
+ ' KeyBaseInstallDir = '#039'BaseInstallDir'#039';'#013#010+
|
|
|
+ ' KeyUnitInstallDir = '#039'UnitInstallDir'#039';'#013#010+
|
|
|
+ ' KeyBinInstallDir = '#039'BinInstallDir'#039';'#013#010+
|
|
|
+ ' KeyDocInstallDir = '#039'DocInstallDir'#039';'#013#010+
|
|
|
+ ' KeyExamplesInstallDir = '#039'Examp','lesInstallDir'#039';'#013#010+
|
|
|
+ ' KeyInstallExamples = '#039'InstallExamples'#039';'#013#010+
|
|
|
+ ' KeySkipCrossProdrams = '#039'SkipCrossPrograms'#039';'#013#010+
|
|
|
+ ' // Keys for unit config'#013#010+
|
|
|
+ ' KeyName = '#039'Name'#039';'#013#010+
|
|
|
+ ' KeyVersion = '#039'Version'#039';'#013#010+
|
|
|
+ ' KeyChecksum = '#039'Checksum'#039';'#013#010+
|
|
|
+ ' KeyNeedLibC = '#039'Nee','dLibC'#039';'#013#010+
|
|
|
+ ' KeyDepends = '#039'Depends'#039';'#013#010+
|
|
|
+ ' KeyFlags = '#039'Flags'#039';'#013#010+
|
|
|
+ ' KeyAddIn = '#039'FPMakeAddIn'#039';'#013#010+
|
|
|
+ ' KeySourcePath = '#039'SourcePath'#039';'#013#010+
|
|
|
+ ' KeyFPMakeOptions = '#039'FPMakeOptions'#039';'#013#010+
|
|
|
+ ' KeyPackageVar = '#039'PackageVariant_'#039';'#013#010+
|
|
|
+ #013#010+
|
|
|
+ '{********************************','***********************************'+
|
|
|
+ '*********'#013#010+
|
|
|
+ ' Helpers'#013#010+
|
|
|
'**********************************************************************'+
|
|
|
- '******}'#010+
|
|
|
- #010+
|
|
|
- '{$ifdef HAS_UNIT_PROCESS}'#010+
|
|
|
- 'function ExecuteFPC(Verbose: boolean; const Path: string; const ComLin'+
|
|
|
- 'e: stri','ng; const Env: TStrings; ConsoleOutput: TMemoryStream): integ'+
|
|
|
- 'er;'#010+
|
|
|
- 'var'#010+
|
|
|
- ' P: TProcess;'#010+
|
|
|
- ' BytesRead: longint;'#010+
|
|
|
- #010+
|
|
|
- ' function ReadFromStream: longint;'#010+
|
|
|
- #010+
|
|
|
- ' const'#010+
|
|
|
- ' READ_BYTES = 2048;'#010+
|
|
|
- #010+
|
|
|
- ' type'#010+
|
|
|
- ' TMessages = (mCompiling, mLinking);'#010+
|
|
|
- #010+
|
|
|
- ' var'#010+
|
|
|
- ' //ifde','f the MsgNum so it contains the correct message numbers fo'+
|
|
|
- 'r each compiler version.'#010+
|
|
|
- ' MsgNum : array [TMessages] of integer = (3104, 9015);'#010+
|
|
|
- #010+
|
|
|
- ' n: longint;'#010+
|
|
|
- ' BuffPos: longint;'#010+
|
|
|
- ' sLine: string;'#010+
|
|
|
- ' ch: char;'#010+
|
|
|
- ' msg: TMessages;'#010+
|
|
|
- ' ipo','s: integer;'#010+
|
|
|
- ' snum: string;'#010+
|
|
|
- ' begin'#010+
|
|
|
- ' // make sure we have room'#010+
|
|
|
- ' ConsoleOutput.SetSize(BytesRead + READ_BYTES);'#010+
|
|
|
- #010+
|
|
|
- ' // try reading it'#010+
|
|
|
- ' n := P.Output.Read((ConsoleOutput.Memory + BytesRead)^, READ_BYTES'+
|
|
|
- ');'#010+
|
|
|
- ' if n > 0 then'#010+
|
|
|
- ' beg','in'#010+
|
|
|
- ' Inc(BytesRead, n);'#010+
|
|
|
- #010+
|
|
|
- ' sLine := '#039#039';'#010+
|
|
|
- ' BuffPos := ConsoleOutput.Position;'#010+
|
|
|
- #010+
|
|
|
- ' //read lines from the stream'#010+
|
|
|
- ' repeat'#010+
|
|
|
- ' ConsoleOutput.Read(ch,1);'#010+
|
|
|
- #010+
|
|
|
- ' if ch in [#10, #13] then'#010+
|
|
|
- ' begin'#010+
|
|
|
- ' if Verbose',' then'#010+
|
|
|
- ' installer.log(vlInfo,sLine)'#010+
|
|
|
- ' else'#010+
|
|
|
- ' begin'#010+
|
|
|
- ' for msg := Low(TMessages) to High(TMessages) do'#010+
|
|
|
- ' begin'#010+
|
|
|
- ' snum := Format('#039'(%d)'#039', [MsgNum[msg]]);'#010+
|
|
|
- ' ipos := ','Pos(snum, sLine);'#010+
|
|
|
- ' if ipos = 1 then'#010+
|
|
|
+ '******}'#013#010+
|
|
|
+ #013#010+
|
|
|
+ '{$ifdef HAS_UNIT_PROCESS}'#013#010+
|
|
|
+ 'function ExecuteFPC(Verbose: boolean; const P','ath: string; const ComL'+
|
|
|
+ 'ine: string; const Env: TStrings; ConsoleOutput: TMemoryStream): integ'+
|
|
|
+ 'er;'#013#010+
|
|
|
+ 'var'#013#010+
|
|
|
+ ' P: TProcess;'#013#010+
|
|
|
+ ' BytesRead: longint;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ ' function ReadFromStream: longint;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ ' const'#013#010+
|
|
|
+ ' READ_BYTES = 2048;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ ' type'#013#010+
|
|
|
+ ' TMessages ','= (mCompiling, mLinking);'#013#010+
|
|
|
+ #013#010+
|
|
|
+ ' var'#013#010+
|
|
|
+ ' //ifdef the MsgNum so it contains the correct message numbers for '+
|
|
|
+ 'each compiler version.'#013#010+
|
|
|
+ ' MsgNum : array [TMessages] of integer = (3104, 9015);'#013#010+
|
|
|
+ #013#010+
|
|
|
+ ' n: longint;'#013#010+
|
|
|
+ ' BuffPos: longint;'#013#010+
|
|
|
+ ' sLine',': string;'#013#010+
|
|
|
+ ' ch: char;'#013#010+
|
|
|
+ ' msg: TMessages;'#013#010+
|
|
|
+ ' ipos: integer;'#013#010+
|
|
|
+ ' snum: string;'#013#010+
|
|
|
+ ' begin'#013#010+
|
|
|
+ ' // make sure we have room'#013#010+
|
|
|
+ ' ConsoleOutput.SetSize(BytesRead + READ_BYTES);'#013#010+
|
|
|
+ #013#010+
|
|
|
+ ' // try reading it'#013#010+
|
|
|
+ ' n := P.Output.Read((ConsoleOutput','.Memory + BytesRead)^, READ_BYT'+
|
|
|
+ 'ES);'#013#010+
|
|
|
+ ' if n > 0 then'#013#010+
|
|
|
+ ' begin'#013#010+
|
|
|
+ ' Inc(BytesRead, n);'#013#010+
|
|
|
+ #013#010+
|
|
|
+ ' sLine := '#039#039';'#013#010+
|
|
|
+ ' BuffPos := ConsoleOutput.Position;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ ' //read lines from the stream'#013#010+
|
|
|
+ ' repeat'#013#010+
|
|
|
+ ' ConsoleOutput.Read(ch,1',');'#013#010+
|
|
|
+ #013#010+
|
|
|
+ ' if ch in [#10, #13] then'#013#010+
|
|
|
+ ' begin'#013#010+
|
|
|
+ ' if Verbose then'#013#010+
|
|
|
+ ' installer.log(vlInfo,sLine)'#013#010+
|
|
|
+ ' else'#013#010+
|
|
|
+ ' begin'#013#010+
|
|
|
+ ' for msg := Low(TMessages) to High(TMessages) do'#013#010+
|
|
|
+ ' begin',#013#010+
|
|
|
+ ' snum := Format('#039'(%d)'#039', [MsgNum[msg]]);'#013#010+
|
|
|
+ ' ipos := Pos(snum, sLine);'#013#010+
|
|
|
+ ' if ipos = 1 then'#013#010+
|
|
|
' installer.log(vlCommand,'#039' '#039'+ Copy(sLine'+
|
|
|
- ', ipos + Length(snum), Length(sLine) - ipos - Length(snum) + 1));'#010+
|
|
|
- ' end;'#010+
|
|
|
- ' end;'#010+
|
|
|
- ' if (LineEnding=','#13#10) and (ch=#13) and'#010+
|
|
|
- ' (ConsoleOutput.Position<BytesRead) then'#010+
|
|
|
- ' begin'#010+
|
|
|
- ' ConsoleOutput.Read(ch,1);'#010+
|
|
|
- ' if ch=#10 then'#010+
|
|
|
- ' sLine:='#039#039#010+
|
|
|
- ' else'#010+
|
|
|
- ' sLine:=ch;'#010+
|
|
|
- ' ',' end'#010+
|
|
|
- ' else'#010+
|
|
|
- ' sLine := '#039#039';'#010+
|
|
|
- ' BuffPos := ConsoleOutput.Position;'#010+
|
|
|
- ' end'#010+
|
|
|
- ' else'#010+
|
|
|
- ' sLine := sLine + ch;'#010+
|
|
|
- #010+
|
|
|
- ' until ConsoleOutput.Position >= BytesRead;'#010+
|
|
|
- #010+
|
|
|
- ' ConsoleOutput.Position := Buf','fPos;'#010+
|
|
|
- ' end'#010+
|
|
|
- ' else'#010+
|
|
|
- ' begin'#010+
|
|
|
- ' // no data, wait 100 ms'#010+
|
|
|
- ' Sleep(100);'#010+
|
|
|
- ' end;'#010+
|
|
|
- #010+
|
|
|
- ' Result := n;'#010+
|
|
|
- ' end;'#010+
|
|
|
- #010+
|
|
|
- 'begin'#010+
|
|
|
- ' result := -1;'#010+
|
|
|
- ' BytesRead := 0;'#010+
|
|
|
- ' P := TProcess.Create(nil);'#010+
|
|
|
- ' try'#010+
|
|
|
- ' P.CommandLine := Path + '#039' '#039' + ComLine;'#010+
|
|
|
- ' if',' assigned(Env) then'#010+
|
|
|
- ' P.Environment.Assign(Env);'#010+
|
|
|
- #010+
|
|
|
- ' P.Options := [poUsePipes];'#010+
|
|
|
- #010+
|
|
|
- ' P.Execute;'#010+
|
|
|
- ' while P.Running do'#010+
|
|
|
- ' ReadFromStream;'#010+
|
|
|
- #010+
|
|
|
- ' // read last part'#010+
|
|
|
- ' repeat'#010+
|
|
|
- ' until ReadFromStream = 0;'#010+
|
|
|
- ' ConsoleOutput.SetSize(Byte','sRead);'#010+
|
|
|
- #010+
|
|
|
- ' result := P.ExitStatus;'#010+
|
|
|
- ' finally'#010+
|
|
|
- ' P.Free;'#010+
|
|
|
- ' end;'#010+
|
|
|
- 'end;'#010+
|
|
|
- '{$endif HAS_UNIT_PROCESS}'#010+
|
|
|
- #010+
|
|
|
- 'function IsDirectoryEmpty(const directory : string) : boolean;'#010+
|
|
|
- 'var'#010+
|
|
|
- ' searchRec: TSearchRec;'#010+
|
|
|
- ' SearchResult: longint;'#010+
|
|
|
- 'begin'#010+
|
|
|
- ' result := true;'#010+
|
|
|
- ' ',' SearchResult := FindFirst(IncludeTrailingPathDelimiter(directory)+'+
|
|
|
- 'AllFilesMask, faAnyFile+faSymLink, searchRec);'#010+
|
|
|
- ' try'#010+
|
|
|
- ' while SearchResult=0 do'#010+
|
|
|
- ' begin'#010+
|
|
|
+ ', ipos + Length(snum), Length(sLine) - ipos',' - Length(snum) + 1));'#013+
|
|
|
+ #010+
|
|
|
+ ' end;'#013#010+
|
|
|
+ ' end;'#013#010+
|
|
|
+ ' if (LineEnding=#13#10) and (ch=#13) and'#013#010+
|
|
|
+ ' (ConsoleOutput.Position<BytesRead) then'#013#010+
|
|
|
+ ' begin'#013#010+
|
|
|
+ ' ConsoleOutput.Read(ch,1);'#013#010+
|
|
|
+ ' ',' if ch=#10 then'#013#010+
|
|
|
+ ' sLine:='#039#039#013#010+
|
|
|
+ ' else'#013#010+
|
|
|
+ ' sLine:=ch;'#013#010+
|
|
|
+ ' end'#013#010+
|
|
|
+ ' else'#013#010+
|
|
|
+ ' sLine := '#039#039';'#013#010+
|
|
|
+ ' BuffPos := ConsoleOutput.Position;'#013#010+
|
|
|
+ ' end'#013#010+
|
|
|
+ ' else'#013#010+
|
|
|
+ ' sLine ',':= sLine + ch;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ ' until ConsoleOutput.Position >= BytesRead;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ ' ConsoleOutput.Position := BuffPos;'#013#010+
|
|
|
+ ' end'#013#010+
|
|
|
+ ' else'#013#010+
|
|
|
+ ' begin'#013#010+
|
|
|
+ ' // no data, wait 100 ms'#013#010+
|
|
|
+ ' Sleep(100);'#013#010+
|
|
|
+ ' end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ ' Result := n;'#013#010+
|
|
|
+ ' end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' ',' result := -1;'#013#010+
|
|
|
+ ' BytesRead := 0;'#013#010+
|
|
|
+ ' P := TProcess.Create(nil);'#013#010+
|
|
|
+ ' try'#013#010+
|
|
|
+ ' P.CommandLine := Path + '#039' '#039' + ComLine;'#013#010+
|
|
|
+ ' if assigned(Env) then'#013#010+
|
|
|
+ ' P.Environment.Assign(Env);'#013#010+
|
|
|
+ #013#010+
|
|
|
+ ' P.Options := [poUsePipes];'#013#010+
|
|
|
+ #013#010+
|
|
|
+ ' P.Execute;'#013#010+
|
|
|
+ ' while P','.Running do'#013#010+
|
|
|
+ ' ReadFromStream;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ ' // read last part'#013#010+
|
|
|
+ ' repeat'#013#010+
|
|
|
+ ' until ReadFromStream = 0;'#013#010+
|
|
|
+ ' ConsoleOutput.SetSize(BytesRead);'#013#010+
|
|
|
+ #013#010+
|
|
|
+ ' result := P.ExitStatus;'#013#010+
|
|
|
+ ' finally'#013#010+
|
|
|
+ ' P.Free;'#013#010+
|
|
|
+ ' end;'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ '{$endif HAS_UNIT_PROCESS}'#013#010+
|
|
|
+ #013,#010+
|
|
|
+ 'function IsDirectoryEmpty(const directory : string) : boolean;'#013#010+
|
|
|
+ 'var'#013#010+
|
|
|
+ ' searchRec: TSearchRec;'#013#010+
|
|
|
+ ' SearchResult: longint;'#013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' result := true;'#013#010+
|
|
|
+ ' SearchResult := FindFirst(IncludeTrailingPathDelimiter(directory)+Al'+
|
|
|
+ 'lFilesMask, faAnyFile+','faSymLink, searchRec);'#013#010+
|
|
|
+ ' try'#013#010+
|
|
|
+ ' while SearchResult=0 do'#013#010+
|
|
|
+ ' begin'#013#010+
|
|
|
' if (searchRec.Name<>'#039'.'#039') and (searchRec.Name<>'#039'..'#039+
|
|
|
- ') then'#010+
|
|
|
- ' begi','n'#010+
|
|
|
- ' result := false;'#010+
|
|
|
- ' break;'#010+
|
|
|
- ' end;'#010+
|
|
|
- ' SearchResult := FindNext(searchRec);'#010+
|
|
|
- ' end;'#010+
|
|
|
- ' finally'#010+
|
|
|
- ' FindClose(searchRec);'#010+
|
|
|
- ' end;'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
- 'function ParsecompilerOutput(M: TMemoryStream; Verbose: boolean): s','t'+
|
|
|
- 'ring;'#010+
|
|
|
- 'type'#010+
|
|
|
- ' TParseCompilerOutputState = (cosBeginOfLine, cosSearchColon, cosPars'+
|
|
|
- 'eNumber, cosOther);'#010+
|
|
|
- #010+
|
|
|
- 'var'#010+
|
|
|
- ' presult: pchar;'#010+
|
|
|
- ' state: TParseCompilerOutputState;'#010+
|
|
|
- ' ch: char;'#010+
|
|
|
- ' eolchar: char;'#010+
|
|
|
- 'begin'#010+
|
|
|
- ' m.Seek(0, soBeginning);'#010+
|
|
|
- ' setlength(Result',',M.Size);'#010+
|
|
|
- #010+
|
|
|
- ' if verbose then'#010+
|
|
|
- ' begin'#010+
|
|
|
- ' m.Read(Result[1],M.Size);'#010+
|
|
|
- ' Exit;'#010+
|
|
|
- ' end;'#010+
|
|
|
- #010+
|
|
|
- ' presult := @Result[1];'#010+
|
|
|
- ' eolchar := RightStr(LineEnding,1)[1];'#010+
|
|
|
- ' m.Seek(0,soBeginning);'#010+
|
|
|
- ' state := cosBeginOfLine;'#010+
|
|
|
- ' while m.Position<m.Size do'#010+
|
|
|
- ' ',' begin'#010+
|
|
|
- ' ch := char(m.ReadByte);'#010+
|
|
|
- ' case state of'#010+
|
|
|
- ' cosBeginOfLine:'#010+
|
|
|
- ' begin'#010+
|
|
|
- ' if ch='#039'('#039' then'#010+
|
|
|
- ' state := cosParseNumber'#010+
|
|
|
- ' else if ch='#039' '#039' then'#010+
|
|
|
- ' begin'#010+
|
|
|
- ' presult^',' := ch;'#010+
|
|
|
- ' inc(presult);'#010+
|
|
|
- ' end'#010+
|
|
|
- ' else'#010+
|
|
|
- ' begin'#010+
|
|
|
- ' presult^ := ch;'#010+
|
|
|
- ' inc(presult);'#010+
|
|
|
- ' state := cosSearchColon;'#010+
|
|
|
- ' end;'#010+
|
|
|
- ' end;'#010+
|
|
|
- ' co','sParseNumber:'#010+
|
|
|
- ' begin'#010+
|
|
|
- ' if ch='#039')'#039' then'#010+
|
|
|
- ' begin'#010+
|
|
|
- ' state := cosOther;'#010+
|
|
|
- ' // Omit the space behind the number'#010+
|
|
|
- ' ch := char(m.ReadByte);'#010+
|
|
|
- ' assert(ch='#039' '#039');'#010+
|
|
|
- ' ',' end;'#010+
|
|
|
- ' end;'#010+
|
|
|
- ' cosOther:'#010+
|
|
|
- ' begin'#010+
|
|
|
- ' presult^ := ch;'#010+
|
|
|
- ' inc(presult);'#010+
|
|
|
- ' if ch=eolchar then'#010+
|
|
|
- ' state := cosBeginOfLine;'#010+
|
|
|
- ' end;'#010+
|
|
|
- ' cosSearchColon:'#010+
|
|
|
- ' begin'#010+
|
|
|
- ' ',' presult^ := ch;'#010+
|
|
|
- ' inc(presult);'#010+
|
|
|
- ' if (ch='#039':'#039') or (ch=eolchar) then'#010+
|
|
|
- ' state := cosBeginOfLine;'#010+
|
|
|
- ' end;'#010+
|
|
|
- ' end;'#010+
|
|
|
- ' end;'#010+
|
|
|
- ' setlength(Result,presult-@result[1]);'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
- 'Function QuoteXML(S : Stri','ng) : string;'#010+
|
|
|
- #010+
|
|
|
- ' Procedure W(Var J : Integer; Var R : String; T : String);'#010+
|
|
|
- ' Var'#010+
|
|
|
- ' I: integer;'#010+
|
|
|
- ' begin'#010+
|
|
|
- ' If J+Length(T)>Length(R) then'#010+
|
|
|
- ' SetLength(R,J+Length(T));'#010+
|
|
|
- ' For I:=1 to Length(t) do'#010+
|
|
|
- ' begin'#010+
|
|
|
- ' R[J]:=T[i];'#010+
|
|
|
- ' If I','<Length(T) then'#010+
|
|
|
- ' Inc(J);'#010+
|
|
|
- ' end;'#010+
|
|
|
- ' end;'#010+
|
|
|
- #010+
|
|
|
- 'const'#010+
|
|
|
- ' QuotStr = '#039'"'#039';'#010+
|
|
|
- ' AmpStr = '#039'&'#039';'#010+
|
|
|
- ' ltStr = '#039'<'#039';'#010+
|
|
|
- ' gtStr = '#039'>'#039';'#010+
|
|
|
- 'Var'#010+
|
|
|
- ' I,J : Integer;'#010+
|
|
|
- 'begin'#010+
|
|
|
- ' SetLength(Result,Length(S));'#010+
|
|
|
- ' J:=0;'#010+
|
|
|
- ' For I:=1 to Length(S) do'#010+
|
|
|
- ' begin'#010+
|
|
|
- ' ',' Inc(J);'#010+
|
|
|
- ' case S[i] of'#010+
|
|
|
- ' '#039'"'#039': W(j,Result,QuotStr);'#010+
|
|
|
- ' '#039'&'#039': W(J,Result,AmpStr);'#010+
|
|
|
- ' '#039'<'#039': W(J,Result,ltStr);'#010+
|
|
|
- ' '#039'>'#039': W(J,Result,gtStr);'#010+
|
|
|
- ' // Escape whitespace using CharRefs to be consistent with W3 spe'+
|
|
|
- 'c X 3.3.3'#010+
|
|
|
- ' #9:',' w(J,Result,'#039'	'#039');'#010+
|
|
|
- '{ #10: wrtStr('#039'
'#039');'#010+
|
|
|
- ' #13: wrtStr('#039'
'#039');}'#010+
|
|
|
- ' else'#010+
|
|
|
- ' Result[J]:=S[i];'#010+
|
|
|
- ' end;'#010+
|
|
|
- ' If (J=Length(Result)) and (I<Length(S)) then'#010+
|
|
|
- ' SetLength(Result,J+Length(S)-I);'#010+
|
|
|
- ' end;'#010+
|
|
|
- ' If J<>Length(Result',') then'#010+
|
|
|
- ' SetLength(Result,J);'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
- #010+
|
|
|
- 'function maybequoted(const s:string):string;'#010+
|
|
|
- 'const'#010+
|
|
|
- ' {$IFDEF MSWINDOWS}'#010+
|
|
|
+ ') then'#013#010+
|
|
|
+ ' begin'#013#010+
|
|
|
+ ' result := false;'#013#010+
|
|
|
+ ' break;'#013#010+
|
|
|
+ ' end;'#013#010+
|
|
|
+ ' Search','Result := FindNext(searchRec);'#013#010+
|
|
|
+ ' end;'#013#010+
|
|
|
+ ' finally'#013#010+
|
|
|
+ ' FindClose(searchRec);'#013#010+
|
|
|
+ ' end;'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ 'function ParsecompilerOutput(M: TMemoryStream; Verbose: boolean): stri'+
|
|
|
+ 'ng;'#013#010+
|
|
|
+ 'type'#013#010+
|
|
|
+ ' TParseCompilerOutputState = (cosBeginOfLine, cosSearchColon',', cosPa'+
|
|
|
+ 'rseNumber, cosOther);'#013#010+
|
|
|
+ #013#010+
|
|
|
+ 'var'#013#010+
|
|
|
+ ' presult: pchar;'#013#010+
|
|
|
+ ' state: TParseCompilerOutputState;'#013#010+
|
|
|
+ ' ch: char;'#013#010+
|
|
|
+ ' eolchar: char;'#013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' m.Seek(0, soBeginning);'#013#010+
|
|
|
+ ' setlength(Result,M.Size);'#013#010+
|
|
|
+ #013#010+
|
|
|
+ ' if verbose then'#013#010+
|
|
|
+ ' begin'#013#010+
|
|
|
+ ' m.Read(Result[1','],M.Size);'#013#010+
|
|
|
+ ' Exit;'#013#010+
|
|
|
+ ' end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ ' presult := @Result[1];'#013#010+
|
|
|
+ ' eolchar := RightStr(LineEnding,1)[1];'#013#010+
|
|
|
+ ' m.Seek(0,soBeginning);'#013#010+
|
|
|
+ ' state := cosBeginOfLine;'#013#010+
|
|
|
+ ' while m.Position<m.Size do'#013#010+
|
|
|
+ ' begin'#013#010+
|
|
|
+ ' ch := char(m.ReadByte);'#013#010+
|
|
|
+ ' case',' state of'#013#010+
|
|
|
+ ' cosBeginOfLine:'#013#010+
|
|
|
+ ' begin'#013#010+
|
|
|
+ ' if ch='#039'('#039' then'#013#010+
|
|
|
+ ' state := cosParseNumber'#013#010+
|
|
|
+ ' else if ch='#039' '#039' then'#013#010+
|
|
|
+ ' begin'#013#010+
|
|
|
+ ' presult^ := ch;'#013#010+
|
|
|
+ ' inc(presult);'#013#010+
|
|
|
+ ' ',' end'#013#010+
|
|
|
+ ' else'#013#010+
|
|
|
+ ' begin'#013#010+
|
|
|
+ ' presult^ := ch;'#013#010+
|
|
|
+ ' inc(presult);'#013#010+
|
|
|
+ ' state := cosSearchColon;'#013#010+
|
|
|
+ ' end;'#013#010+
|
|
|
+ ' end;'#013#010+
|
|
|
+ ' cosParseNumber:'#013#010+
|
|
|
+ ' begin'#013#010,
|
|
|
+ ' if ch='#039')'#039' then'#013#010+
|
|
|
+ ' begin'#013#010+
|
|
|
+ ' state := cosOther;'#013#010+
|
|
|
+ ' // Omit the space behind the number'#013#010+
|
|
|
+ ' ch := char(m.ReadByte);'#013#010+
|
|
|
+ ' assert(ch='#039' '#039');'#013#010+
|
|
|
+ ' end;'#013#010+
|
|
|
+ ' end;'#013#010,
|
|
|
+ ' cosOther:'#013#010+
|
|
|
+ ' begin'#013#010+
|
|
|
+ ' presult^ := ch;'#013#010+
|
|
|
+ ' inc(presult);'#013#010+
|
|
|
+ ' if ch=eolchar then'#013#010+
|
|
|
+ ' state := cosBeginOfLine;'#013#010+
|
|
|
+ ' end;'#013#010+
|
|
|
+ ' cosSearchColon:'#013#010+
|
|
|
+ ' begin'#013#010+
|
|
|
+ ' presul','t^ := ch;'#013#010+
|
|
|
+ ' inc(presult);'#013#010+
|
|
|
+ ' if (ch='#039':'#039') or (ch=eolchar) then'#013#010+
|
|
|
+ ' state := cosBeginOfLine;'#013#010+
|
|
|
+ ' end;'#013#010+
|
|
|
+ ' end;'#013#010+
|
|
|
+ ' end;'#013#010+
|
|
|
+ ' setlength(Result,presult-@result[1]);'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ 'Function QuoteXML(S : String)',' : string;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ ' Procedure W(Var J : Integer; Var R : String; T : String);'#013#010+
|
|
|
+ ' Var'#013#010+
|
|
|
+ ' I: integer;'#013#010+
|
|
|
+ ' begin'#013#010+
|
|
|
+ ' If J+Length(T)>Length(R) then'#013#010+
|
|
|
+ ' SetLength(R,J+Length(T));'#013#010+
|
|
|
+ ' For I:=1 to Length(t) do'#013#010+
|
|
|
+ ' begin'#013#010+
|
|
|
+ ' R[J]:=T[i];'#013#010+
|
|
|
+ ' ',' If I<Length(T) then'#013#010+
|
|
|
+ ' Inc(J);'#013#010+
|
|
|
+ ' end;'#013#010+
|
|
|
+ ' end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ 'const'#013#010+
|
|
|
+ ' QuotStr = '#039'"'#039';'#013#010+
|
|
|
+ ' AmpStr = '#039'&'#039';'#013#010+
|
|
|
+ ' ltStr = '#039'<'#039';'#013#010+
|
|
|
+ ' gtStr = '#039'>'#039';'#013#010+
|
|
|
+ 'Var'#013#010+
|
|
|
+ ' I,J : Integer;'#013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' SetLength(Result,Length(S));'#013#010+
|
|
|
+ ' J:=0;'#013#010+
|
|
|
+ ' For I:=1 to Le','ngth(S) do'#013#010+
|
|
|
+ ' begin'#013#010+
|
|
|
+ ' Inc(J);'#013#010+
|
|
|
+ ' case S[i] of'#013#010+
|
|
|
+ ' '#039'"'#039': W(j,Result,QuotStr);'#013#010+
|
|
|
+ ' '#039'&'#039': W(J,Result,AmpStr);'#013#010+
|
|
|
+ ' '#039'<'#039': W(J,Result,ltStr);'#013#010+
|
|
|
+ ' '#039'>'#039': W(J,Result,gtStr);'#013#010+
|
|
|
+ ' // Escape whitespace using CharRefs to be consistent ','with W3 s'+
|
|
|
+ 'pec X 3.3.3'#013#010+
|
|
|
+ ' #9: w(J,Result,'#039'	'#039');'#013#010+
|
|
|
+ '{ #10: wrtStr('#039'
'#039');'#013#010+
|
|
|
+ ' #13: wrtStr('#039'
'#039');}'#013#010+
|
|
|
+ ' else'#013#010+
|
|
|
+ ' Result[J]:=S[i];'#013#010+
|
|
|
+ ' end;'#013#010+
|
|
|
+ ' If (J=Length(Result)) and (I<Length(S)) then'#013#010+
|
|
|
+ ' SetLength(Result,J+Lengt','h(S)-I);'#013#010+
|
|
|
+ ' end;'#013#010+
|
|
|
+ ' If J<>Length(Result) then'#013#010+
|
|
|
+ ' SetLength(Result,J);'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ #013#010+
|
|
|
+ 'function maybequoted(const s:string):string;'#013#010+
|
|
|
+ 'const'#013#010+
|
|
|
+ ' {$IFDEF MSWINDOWS}'#013#010+
|
|
|
' FORBIDDEN_CHARS = ['#039'!'#039', '#039'@'#039', '#039'#'#039', '#039'$'#039+
|
|
|
', '#039'%'#039', '#039'^'#039', '#039'&'#039', '#039'*'#039', '#039'('#039', '#039+
|
|
|
- ')'#039','#010+
|
|
|
- ' '#039'{'#039', '#039'}'#039', '#039#039#039#039', '#039'`'+
|
|
|
- #039', '#039'~'#039'];'#010+
|
|
|
- ' {$EL','SE}'#010+
|
|
|
+ ')'#039','#013#010+
|
|
|
+ ' ',' '#039'{'#039', '#039'}'#039', '#039#039#039#039', '#039+
|
|
|
+ '`'#039', '#039'~'#039'];'#013#010+
|
|
|
+ ' {$ELSE}'#013#010+
|
|
|
' FORBIDDEN_CHARS = ['#039'!'#039', '#039'@'#039', '#039'#'#039', '#039'$'#039+
|
|
|
', '#039'%'#039', '#039'^'#039', '#039'&'#039', '#039'*'#039', '#039'('#039', '#039+
|
|
|
- ')'#039','#010+
|
|
|
+ ')'#039','#013#010+
|
|
|
' '#039'{'#039', '#039'}'#039', '#039#039#039#039', '#039':'+
|
|
|
- #039', '#039'\'#039', '#039'`'#039', '#039'~'#039'];'#010+
|
|
|
- ' {$ENDIF}'#010+
|
|
|
- 'var'#010+
|
|
|
- ' s1 : string;'#010+
|
|
|
- ' i : integer;'#010+
|
|
|
- ' quoted : boolean;'#010+
|
|
|
- 'begin'#010+
|
|
|
- ' quoted:=false;'#010+
|
|
|
- ' s1:='#039'"'#039';'#010+
|
|
|
- ' f','or i:=1 to length(s) do'#010+
|
|
|
- ' begin'#010+
|
|
|
- ' case s[i] of'#010+
|
|
|
- ' '#039'"'#039' :'#010+
|
|
|
- ' begin'#010+
|
|
|
- ' quoted:=true;'#010+
|
|
|
- ' s1:=s1+'#039'\"'#039';'#010+
|
|
|
- ' end;'#010+
|
|
|
- ' '#039' '#039','#010+
|
|
|
- ' #128..#255 :'#010+
|
|
|
- ' begin'#010+
|
|
|
- ' quoted:=true;'#010+
|
|
|
- ' s1:=s1+s[i];'#010+
|
|
|
- ' ',' end;'#010+
|
|
|
- ' else begin'#010+
|
|
|
- ' if s[i] in FORBIDDEN_CHARS then'#010+
|
|
|
- ' quoted:=True;'#010+
|
|
|
- ' s1:=s1+s[i];'#010+
|
|
|
- ' end;'#010+
|
|
|
- ' end;'#010+
|
|
|
- ' end;'#010+
|
|
|
- ' if quoted then'#010+
|
|
|
- ' maybequoted:=s1+'#039'"'#039#010+
|
|
|
- ' else'#010+
|
|
|
- ' maybequoted:=s;'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
- #010+
|
|
|
- 'procedure ReadIni','File(Const AFileName: String;L:TStrings);'#010+
|
|
|
- 'Var'#010+
|
|
|
- ' F : TFileStream;'#010+
|
|
|
- ' Line : String;'#010+
|
|
|
- ' I,P,PC : Integer;'#010+
|
|
|
- 'begin'#010+
|
|
|
- ' // On some file systems and when using a large number of parallel ma'+
|
|
|
- 'ke'#010+
|
|
|
- ' // processes, the lock from the creation of the ini file ','may not y'+
|
|
|
- 'et'#010+
|
|
|
- ' // have been released even though the file has been closed already'#010+
|
|
|
- ' F:=TFileStream.Create(AFileName,fmOpenRead or fmShareDenyNone);'#010+
|
|
|
- ' Try'#010+
|
|
|
- ' L.LoadFromStream(F);'#010+
|
|
|
- ' // Fix lines.'#010+
|
|
|
- ' For I:=L.Count-1 downto 0 do'#010+
|
|
|
- ' begin',#010+
|
|
|
- ' Line:=L[I];'#010+
|
|
|
- ' P:=Pos('#039'='#039',Line);'#010+
|
|
|
- ' PC:=Pos('#039';'#039',Line); // Comment line.'#010+
|
|
|
- ' If (P=0) or ((PC<>0) and (PC<P)) then'#010+
|
|
|
- ' L.Delete(I)'#010+
|
|
|
- ' else'#010+
|
|
|
+ #039', '#039'\'#039', '#039'`'#039', '#039'~'#039'];'#013#010+
|
|
|
+ ' {$ENDIF}'#013#010+
|
|
|
+ 'var'#013#010+
|
|
|
+ ' s1 : string;'#013#010+
|
|
|
+ ' i : integer;'#013,#010+
|
|
|
+ ' quoted : boolean;'#013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' quoted:=false;'#013#010+
|
|
|
+ ' s1:='#039'"'#039';'#013#010+
|
|
|
+ ' for i:=1 to length(s) do'#013#010+
|
|
|
+ ' begin'#013#010+
|
|
|
+ ' case s[i] of'#013#010+
|
|
|
+ ' '#039'"'#039' :'#013#010+
|
|
|
+ ' begin'#013#010+
|
|
|
+ ' quoted:=true;'#013#010+
|
|
|
+ ' s1:=s1+'#039'\"'#039';'#013#010+
|
|
|
+ ' end;'#013#010+
|
|
|
+ ' '#039' '#039','#013#010+
|
|
|
+ ' #128..#2','55 :'#013#010+
|
|
|
+ ' begin'#013#010+
|
|
|
+ ' quoted:=true;'#013#010+
|
|
|
+ ' s1:=s1+s[i];'#013#010+
|
|
|
+ ' end;'#013#010+
|
|
|
+ ' else begin'#013#010+
|
|
|
+ ' if s[i] in FORBIDDEN_CHARS then'#013#010+
|
|
|
+ ' quoted:=True;'#013#010+
|
|
|
+ ' s1:=s1+s[i];'#013#010+
|
|
|
+ ' end;'#013#010+
|
|
|
+ ' end;'#013#010+
|
|
|
+ ' end;'#013#010+
|
|
|
+ ' if quot','ed then'#013#010+
|
|
|
+ ' maybequoted:=s1+'#039'"'#039#013#010+
|
|
|
+ ' else'#013#010+
|
|
|
+ ' maybequoted:=s;'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ #013#010+
|
|
|
+ 'procedure ReadIniFile(Const AFileName: String;L:TStrings);'#013#010+
|
|
|
+ 'Var'#013#010+
|
|
|
+ ' F : TFileStream;'#013#010+
|
|
|
+ ' Line : String;'#013#010+
|
|
|
+ ' I,P,PC : Integer;'#013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' // On some file systems and when u','sing a large number of parallel '+
|
|
|
+ 'make'#013#010+
|
|
|
+ ' // processes, the lock from the creation of the ini file may not yet'+
|
|
|
+ #013#010+
|
|
|
+ ' // have been released even though the file has been closed already'#013+
|
|
|
+ #010+
|
|
|
+ ' F:=TFileStream.Create(AFileName,fmOpenRead or fmShareDenyN','one);'#013+
|
|
|
+ #010+
|
|
|
+ ' Try'#013#010+
|
|
|
+ ' L.LoadFromStream(F);'#013#010+
|
|
|
+ ' // Fix lines.'#013#010+
|
|
|
+ ' For I:=L.Count-1 downto 0 do'#013#010+
|
|
|
+ ' begin'#013#010+
|
|
|
+ ' Line:=L[I];'#013#010+
|
|
|
+ ' P:=Pos('#039'='#039',Line);'#013#010+
|
|
|
+ ' PC:=Pos('#039';'#039',Line); // Comment line.'#013#010+
|
|
|
+ ' If (P=0) or ((PC<>0) and (PC<P))',' then'#013#010+
|
|
|
+ ' L.Delete(I)'#013#010+
|
|
|
+ ' else'#013#010+
|
|
|
' L[i]:=Trim(System.Copy(Line,1,P-1)+'#039'='#039'+Trim(System.C'+
|
|
|
- 'opy(L','ine,P+1,Length(Line)-P)));'#010+
|
|
|
- ' end;'#010+
|
|
|
- ' Finally'#010+
|
|
|
- ' F.Free;'#010+
|
|
|
- ' end;'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
- #010+
|
|
|
- '// Callback for Sysutils getapplicationname.'#010+
|
|
|
- 'Function GetFPMakeName : String;'#010+
|
|
|
- #010+
|
|
|
- 'begin'#010+
|
|
|
- ' Result:='#039'fpmake'#039';'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
- #010+
|
|
|
- 'Function CurrentOS : String;'#010+
|
|
|
- #010+
|
|
|
- 'begin'#010+
|
|
|
- ' Result:=OSToStri','ng(Defaults.OS);'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
- 'Function CurrentCPU : String;'#010+
|
|
|
- #010+
|
|
|
- 'begin'#010+
|
|
|
- ' Result:=CPUToString(Defaults.CPU);'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
- 'Function OSToString(OS: TOS) : String;'#010+
|
|
|
- #010+
|
|
|
- 'begin'#010+
|
|
|
- ' Result:=LowerCase(GetenumName(TypeInfo(TOS),Ord(OS)));'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
- 'Function OSesToString(OSes: ','TOSes) : String;'#010+
|
|
|
- #010+
|
|
|
- 'var'#010+
|
|
|
- ' i: TOS;'#010+
|
|
|
- ' Tmp: String;'#010+
|
|
|
- ' First: boolean;'#010+
|
|
|
- #010+
|
|
|
- 'begin'#010+
|
|
|
- ' { can'#039't use SetToString, there are more than 32 OSes }'#010+
|
|
|
- ' First:=true;'#010+
|
|
|
- ' for i in OSes do'#010+
|
|
|
- ' begin'#010+
|
|
|
- ' if not First then'#010+
|
|
|
- ' Result:=Result+'#039','#039#010+
|
|
|
- ' else'#010+
|
|
|
- ' ',' First:=false;'#010+
|
|
|
- ' Str(i,Tmp);'#010+
|
|
|
- ' Result:=Result+Tmp;'#010+
|
|
|
- ' end;'#010+
|
|
|
- ' Result:=LowerCase(Tmp);'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
- 'Function CPUToString(CPU: TCPU) : String;'#010+
|
|
|
- #010+
|
|
|
- 'begin'#010+
|
|
|
- ' Result:=LowerCase(GetenumName(TypeInfo(TCPU),Ord(CPU)));'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
- 'Function CPUSToString(CP','US: TCPUS) : String;'#010+
|
|
|
- #010+
|
|
|
- 'begin'#010+
|
|
|
- ' Result:=LowerCase(SetToString(PTypeInfo(TypeInfo(TCPUS)),Integer(CPU'+
|
|
|
- 'S),False));'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
- 'Function StringToOS(const S : String) : TOS;'#010+
|
|
|
- #010+
|
|
|
- 'Var'#010+
|
|
|
- ' I : Integer;'#010+
|
|
|
- #010+
|
|
|
- 'begin'#010+
|
|
|
- ' I:=GetEnumValue(TypeInfo(TOS),S);'#010+
|
|
|
- ' if (I=-1) then',#010+
|
|
|
- ' Raise EInstallerError.CreateFmt(SErrInvalidOS,[S]);'#010+
|
|
|
- ' Result:=TOS(I);'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
- '(*'#010+
|
|
|
- 'Function StringToOSes(const S : String) : TOSes;'#010+
|
|
|
- #010+
|
|
|
- 'begin'#010+
|
|
|
- ' Result:=TOSes(StringToSet(PTypeInfo(TypeInfo(TOSes)),S));'#010+
|
|
|
- 'end;'#010+
|
|
|
- '*)'#010+
|
|
|
- #010+
|
|
|
- 'function IsDifferentFromBuild(A','Cpu: TCPU; AOs: TOs): boolean;'#010+
|
|
|
- 'begin'#010+
|
|
|
- ' result := (AOs<>Defaults.BuildOS) or (ACpu<>Defaults.BuildCPU);'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
- 'Function StringToCPU(const S : String) : TCPU;'#010+
|
|
|
- #010+
|
|
|
- 'Var'#010+
|
|
|
- ' I : Integer;'#010+
|
|
|
- #010+
|
|
|
- 'begin'#010+
|
|
|
- ' I:=GetEnumValue(TypeInfo(TCPU),S);'#010+
|
|
|
- ' if (I=-1) then'#010+
|
|
|
- ' ',' Raise EInstallerError.CreateFmt(SErrInvalidCPU,[S]);'#010+
|
|
|
- ' Result:=TCPU(I);'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
- 'Function StringToCPUS(const S : String) : TCPUS;'#010+
|
|
|
- #010+
|
|
|
- 'begin'#010+
|
|
|
- ' Result:=TCPUS(StringToSet(PTypeInfo(TypeInfo(TCPUS)),S));'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
- 'Function ModeToString(Mode: TCompilerMo','de) : String;'#010+
|
|
|
- #010+
|
|
|
- 'begin'#010+
|
|
|
- ' Result:=LowerCase(GetenumName(TypeInfo(TCompilerMode),Ord(Mode)));'#010+
|
|
|
- ' Delete(Result,1,2);'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
- 'Function StringToMode(const S : String) : TCompilerMode;'#010+
|
|
|
- #010+
|
|
|
- 'Var'#010+
|
|
|
- ' I : Integer;'#010+
|
|
|
- #010+
|
|
|
- 'begin'#010+
|
|
|
- ' I:=GetEnumValue(TypeInfo(TCompilerMo','de),S);'#010+
|
|
|
- ' if (I=-1) then'#010+
|
|
|
- ' Raise EInstallerError.CreateFmt(SErrInvalidMode,[S]);'#010+
|
|
|
- ' Result:=TCompilerMode(I);'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
- #010+
|
|
|
- 'Function MakeTargetString(CPU : TCPU;OS: TOS) : String;'#010+
|
|
|
- #010+
|
|
|
- 'begin'#010+
|
|
|
- ' if OS in AllLimit83fsOses then'#010+
|
|
|
- ' Result := OSToString(O','S)'#010+
|
|
|
- ' else'#010+
|
|
|
- ' Result:=CPUToString(CPU)+'#039'-'#039'+OSToString(OS);'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
+ 'opy(Line,P+1,Length(Line)-P)));'#013#010+
|
|
|
+ ' end;'#013#010+
|
|
|
+ ' Finally'#013#010+
|
|
|
+ ' F.Free;'#013#010+
|
|
|
+ ' end;'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ #013#010+
|
|
|
+ '// Callback for Sysutils getapplicationname.'#013#010+
|
|
|
+ 'F','unction GetFPMakeName : String;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' Result:='#039'fpmake'#039';'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ #013#010+
|
|
|
+ 'Function CurrentOS : String;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' Result:=OSToString(Defaults.OS);'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ 'Function CurrentCPU : String;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' Result:=CPUToString(Defaults.CPU);'#013#010+
|
|
|
+ 'end;'#013#010,
|
|
|
+ #013#010+
|
|
|
+ 'Function OSToString(OS: TOS) : String;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' Result:=LowerCase(GetenumName(TypeInfo(TOS),Ord(OS)));'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ 'Function OSesToString(OSes: TOSes) : String;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ 'var'#013#010+
|
|
|
+ ' i: TOS;'#013#010+
|
|
|
+ ' Tmp: String;'#013#010+
|
|
|
+ ' First: boolean;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' { can'#039't use S','etToString, there are more than 32 OSes }'#013#010+
|
|
|
+ ' First:=true;'#013#010+
|
|
|
+ ' for i in OSes do'#013#010+
|
|
|
+ ' begin'#013#010+
|
|
|
+ ' if not First then'#013#010+
|
|
|
+ ' Result:=Result+'#039','#039#013#010+
|
|
|
+ ' else'#013#010+
|
|
|
+ ' First:=false;'#013#010+
|
|
|
+ ' Str(i,Tmp);'#013#010+
|
|
|
+ ' Result:=Result+Tmp;'#013#010+
|
|
|
+ ' end;'#013#010+
|
|
|
+ ' Resu','lt:=LowerCase(Tmp);'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ 'Function CPUToString(CPU: TCPU) : String;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' Result:=LowerCase(GetenumName(TypeInfo(TCPU),Ord(CPU)));'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ 'Function CPUSToString(CPUS: TCPUS) : String;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' Result:=LowerCase(SetToString(PTyp','eInfo(TypeInfo(TCPUS)),Integer(C'+
|
|
|
+ 'PUS),False));'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ 'Function StringToOS(const S : String) : TOS;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ 'Var'#013#010+
|
|
|
+ ' I : Integer;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' I:=GetEnumValue(TypeInfo(TOS),S);'#013#010+
|
|
|
+ ' if (I=-1) then'#013#010+
|
|
|
+ ' Raise EInstallerError.CreateFmt(SErrInvalidOS,[S',']);'#013#010+
|
|
|
+ ' Result:=TOS(I);'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ '(*'#013#010+
|
|
|
+ 'Function StringToOSes(const S : String) : TOSes;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' Result:=TOSes(StringToSet(PTypeInfo(TypeInfo(TOSes)),S));'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ '*)'#013#010+
|
|
|
+ #013#010+
|
|
|
+ 'function IsDifferentFromBuild(ACpu: TCPU; AOs: TOs): boolean;'#013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' ','result := (AOs<>Defaults.BuildOS) or (ACpu<>Defaults.BuildCPU);'#013+
|
|
|
+ #010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ 'Function StringToCPU(const S : String) : TCPU;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ 'Var'#013#010+
|
|
|
+ ' I : Integer;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' I:=GetEnumValue(TypeInfo(TCPU),S);'#013#010+
|
|
|
+ ' if (I=-1) then'#013#010+
|
|
|
+ ' Raise EInstallerError.Creat','eFmt(SErrInvalidCPU,[S]);'#013#010+
|
|
|
+ ' Result:=TCPU(I);'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ 'Function StringToCPUS(const S : String) : TCPUS;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' Result:=TCPUS(StringToSet(PTypeInfo(TypeInfo(TCPUS)),S));'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ 'Function ModeToString(Mode: TCompilerMode) : String;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ 'b','egin'#013#010+
|
|
|
+ ' Result:=LowerCase(GetenumName(TypeInfo(TCompilerMode),Ord(Mode)));'#013+
|
|
|
+ #010+
|
|
|
+ ' Delete(Result,1,2);'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ 'Function StringToMode(const S : String) : TCompilerMode;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ 'Var'#013#010+
|
|
|
+ ' I : Integer;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' I:=GetEnumValue(TypeInfo(TCompilerMode),S',');'#013#010+
|
|
|
+ ' if (I=-1) then'#013#010+
|
|
|
+ ' Raise EInstallerError.CreateFmt(SErrInvalidMode,[S]);'#013#010+
|
|
|
+ ' Result:=TCompilerMode(I);'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ #013#010+
|
|
|
+ 'Function MakeTargetString(CPU : TCPU;OS: TOS) : String;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' if OS in AllLimit83fsOses then'#013#010+
|
|
|
+ ' Result := OSToSt','ring(OS)'#013#010+
|
|
|
+ ' else'#013#010+
|
|
|
+ ' Result:=CPUToString(CPU)+'#039'-'#039'+OSToString(OS);'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
'Procedure StringToCPUOS(const S : String; Var CPU : TCPU; Var OS: TOS)'+
|
|
|
- ';'#010+
|
|
|
- #010+
|
|
|
- 'Var'#010+
|
|
|
- ' P : integer;'#010+
|
|
|
- #010+
|
|
|
- 'begin'#010+
|
|
|
- ' P:=Pos('#039'-'#039',S);'#010+
|
|
|
- ' If (P=0) then'#010+
|
|
|
- ' Raise EInstallerError.CreateFmt(SErrInv','alidTarget,[S]);'#010+
|
|
|
- ' CPU:=StringToCPU(Copy(S,1,P-1));'#010+
|
|
|
- ' OS:=StringToOs(Copy(S,P+1,Length(S)-P));'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
- #010+
|
|
|
+ ';'#013#010+
|
|
|
+ #013#010+
|
|
|
+ 'Var'#013#010+
|
|
|
+ ' P : integer;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' P:=Pos('#039'-'#039',S);'#013#010+
|
|
|
+ ' If (P=0) then'#013#010+
|
|
|
+ ' Raise EInstallerErro','r.CreateFmt(SErrInvalidTarget,[S]);'#013#010+
|
|
|
+ ' CPU:=StringToCPU(Copy(S,1,P-1));'#013#010+
|
|
|
+ ' OS:=StringToOs(Copy(S,P+1,Length(S)-P));'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ #013#010+
|
|
|
'Procedure ResolveDependencies(L : TDependencies; P : TNamedCollection)'+
|
|
|
- ';'#010+
|
|
|
- 'Var'#010+
|
|
|
- ' I,J : Integer;'#010+
|
|
|
- ' C : TDependency;'#010+
|
|
|
- 'begin'#010+
|
|
|
- ' If Assigned(L) the','n'#010+
|
|
|
- ' For I:=0 to L.Count-1 do'#010+
|
|
|
- ' begin'#010+
|
|
|
- ' C:=L[i];'#010+
|
|
|
- ' if C.DependencyType in [depPackage,depUnit] then'#010+
|
|
|
- ' begin'#010+
|
|
|
- ' J:=P.IndexOfName(C.Value);'#010+
|
|
|
- ' If J<>-1 then'#010+
|
|
|
- ' C.Target:=P.Items[J];'#010+
|
|
|
- ' ',' end;'#010+
|
|
|
- ' end;'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
- #010+
|
|
|
+ ';'#013#010+
|
|
|
+ 'Var'#013#010+
|
|
|
+ ' I,J : Integer;'#013#010+
|
|
|
+ ' C : TDependency',';'#013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' If Assigned(L) then'#013#010+
|
|
|
+ ' For I:=0 to L.Count-1 do'#013#010+
|
|
|
+ ' begin'#013#010+
|
|
|
+ ' C:=L[i];'#013#010+
|
|
|
+ ' if C.DependencyType in [depPackage,depUnit] then'#013#010+
|
|
|
+ ' begin'#013#010+
|
|
|
+ ' J:=P.IndexOfName(C.Value);'#013#010+
|
|
|
+ ' If J<>-1 then'#013#010+
|
|
|
+ ' ',' C.Target:=P.Items[J];'#013#010+
|
|
|
+ ' end;'#013#010+
|
|
|
+ ' end;'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ #013#010+
|
|
|
'function AddConditionalStrings(APackage: TPackage; Dest : TStrings; Sr'+
|
|
|
'c : TConditionalStrings;ACPU:TCPU;AOS:TOS; Const APrefix : String='#039+
|
|
|
- #039') : Integer ;'#010+
|
|
|
- 'Var'#010+
|
|
|
- ' I : Integer;'#010+
|
|
|
- ' C : TConditionalString;'#010+
|
|
|
- ' D : TPackageDi','ctionary;'#010+
|
|
|
- ' S : String;'#010+
|
|
|
- 'begin'#010+
|
|
|
- ' Result:=0;'#010+
|
|
|
- ' D := PackageDictionaryClass.Create(nil);'#010+
|
|
|
- ' D.MasterDictionary := APackage.Dictionary;'#010+
|
|
|
- ' try'#010+
|
|
|
- ' D.AddVariable('#039'CPU'#039',CPUToString(ACPU));'#010+
|
|
|
- ' D.AddVariable('#039'OS'#039',OSToString(AOS));'#010+
|
|
|
- ' For I:=0 to Sr','c.Count-1 do'#010+
|
|
|
- ' begin'#010+
|
|
|
- ' C:=Src[I];'#010+
|
|
|
- ' if (ACPU in C.CPUs) and (AOS in C.OSes) then'#010+
|
|
|
- ' begin'#010+
|
|
|
- ' If (APrefix<>'#039#039') then'#010+
|
|
|
- ' S:=APrefix+C.Value'#010+
|
|
|
- ' else'#010+
|
|
|
- ' S:=C.Value;'#010+
|
|
|
- ' S := ','D.ReplaceStrings(s);'#010+
|
|
|
- ' if C is TConditionalDestString then'#010+
|
|
|
- ' begin'#010+
|
|
|
+ #039') : Integer ;'#013#010+
|
|
|
+ 'Var'#013#010+
|
|
|
+ ' I : Integ','er;'#013#010+
|
|
|
+ ' C : TConditionalString;'#013#010+
|
|
|
+ ' D : TPackageDictionary;'#013#010+
|
|
|
+ ' S : String;'#013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' Result:=0;'#013#010+
|
|
|
+ ' D := PackageDictionaryClass.Create(nil);'#013#010+
|
|
|
+ ' D.MasterDictionary := APackage.Dictionary;'#013#010+
|
|
|
+ ' try'#013#010+
|
|
|
+ ' D.AddVariable('#039'CPU'#039',CPUToString(ACPU));'#013#010+
|
|
|
+ ' ',' D.AddVariable('#039'OS'#039',OSToString(AOS));'#013#010+
|
|
|
+ ' For I:=0 to Src.Count-1 do'#013#010+
|
|
|
+ ' begin'#013#010+
|
|
|
+ ' C:=Src[I];'#013#010+
|
|
|
+ ' if (ACPU in C.CPUs) and (AOS in C.OSes) then'#013#010+
|
|
|
+ ' begin'#013#010+
|
|
|
+ ' If (APrefix<>'#039#039') then'#013#010+
|
|
|
+ ' S:=APrefix+C.Val','ue'#013#010+
|
|
|
+ ' else'#013#010+
|
|
|
+ ' S:=C.Value;'#013#010+
|
|
|
+ ' S := D.ReplaceStrings(s);'#013#010+
|
|
|
+ ' if C is TConditionalDestString then'#013#010+
|
|
|
+ ' begin'#013#010+
|
|
|
' // If a destination path is given, omit the path of th'+
|
|
|
- 'e sourcefile'#010+
|
|
|
- ' if TConditionalDestString(c).DestPath='#039#039' then'#010+
|
|
|
- ' ',' Dest.values[S] := D.ReplaceStrings(IncludeTrailin'+
|
|
|
- 'gPathDelimiter(TConditionalDestString(c).DestPath))+S'#010+
|
|
|
- ' else'#010+
|
|
|
- ' Dest.values[S] := D.ReplaceStrings(IncludeTrailingP'+
|
|
|
- 'athDelimiter(TConditionalDestStri','ng(c).DestPath)+APrefix+ExtractFile'+
|
|
|
- 'Name(C.Value));'#010+
|
|
|
- ' end'#010+
|
|
|
- ' else'#010+
|
|
|
- ' Dest.Add(S);'#010+
|
|
|
- ' Inc(Result);'#010+
|
|
|
- ' end;'#010+
|
|
|
- ' end;'#010+
|
|
|
- ' finally'#010+
|
|
|
- ' D.Free;'#010+
|
|
|
- ' end;'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
- #010+
|
|
|
- 'function FileListToString(List : TString','s; const APrefix : String) :'+
|
|
|
- ' String;'#010+
|
|
|
- 'Var'#010+
|
|
|
- ' I : integer;'#010+
|
|
|
- ' S : String;'#010+
|
|
|
- 'begin'#010+
|
|
|
- ' Result:='#039#039';'#010+
|
|
|
- ' For I:=0 to List.Count-1 do'#010+
|
|
|
- ' begin'#010+
|
|
|
- ' If (I>0) then'#010+
|
|
|
- ' Result:=Result+'#039' '#039';'#010+
|
|
|
- ' S:=APrefix+List[i];'#010+
|
|
|
- ' If (Pos('#039' '#039',S)<>0) then'#010+
|
|
|
- ' ',' S:='#039'"'#039'+S+'#039'"'#039';'#010+
|
|
|
- ' Result:=Result+S;'#010+
|
|
|
- ' end;'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
- #010+
|
|
|
- 'function FixPath (const APath : String) : String;'#010+
|
|
|
- 'begin'#010+
|
|
|
- ' Result := FixPath(APath, False);'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
- 'function FixPath (const APath : String; AIsDir : Boolean) : String;'#010+
|
|
|
- 'Var'#010+
|
|
|
- ' P : PChar;'#010+
|
|
|
- 'be','gin'#010+
|
|
|
- ' Result:=APath;'#010+
|
|
|
- ' If (result<>'#039#039') then'#010+
|
|
|
- ' begin'#010+
|
|
|
- ' UniqueString(Result);'#010+
|
|
|
- ' P:=PChar(Result);'#010+
|
|
|
- ' While (P^<>#0) do'#010+
|
|
|
- ' begin'#010+
|
|
|
- ' If P^ in ['#039'/'#039','#039'\'#039'] then'#010+
|
|
|
- ' P^:=PathDelim;'#010+
|
|
|
- ' Inc(P);'#010+
|
|
|
- ' end;'#010+
|
|
|
- ' ','end;'#010+
|
|
|
- ' if AIsDir and (Result <> '#039#039') then'#010+
|
|
|
- ' Result := IncludeTrailingPathDelimiter(Result);;'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
- 'function IsRelativePath(const APath: String): boolean;'#010+
|
|
|
- 'begin'#010+
|
|
|
- ' if APath='#039#039' then'#010+
|
|
|
- ' result := true'#010+
|
|
|
- '{$ifdef unix}'#010+
|
|
|
- ' else if APath[1] in Allow','DirectorySeparators then'#010+
|
|
|
- ' result := false'#010+
|
|
|
- '{$else}'#010+
|
|
|
- ' else if ExtractFileDrive(APath)<>'#039#039' then'#010+
|
|
|
- ' result := false'#010+
|
|
|
- '{$endif}'#010+
|
|
|
- ' else'#010+
|
|
|
- ' result := true;'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
- 'procedure ChangeDir(const APath : String);'#010+
|
|
|
- 'begin'#010+
|
|
|
- ' if Not SetCurrentDir(APath) the','n'#010+
|
|
|
- ' Raise EInstallerError.CreateFmt(SErrChangeDirFailed,[APath]);'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
- #010+
|
|
|
- 'procedure SearchFiles(const AFileName: string; Recursive: boolean; var'+
|
|
|
- ' List: TStrings);'#010+
|
|
|
+ 'e sourcefile',#013#010+
|
|
|
+ ' if TConditionalDestString(c).DestPath='#039#039' then'#013+
|
|
|
#010+
|
|
|
+ ' Dest.values[S] := D.ReplaceStrings(IncludeTrailingP'+
|
|
|
+ 'athDelimiter(TConditionalDestString(c).DestPath))+S'#013#010+
|
|
|
+ ' else'#013#010+
|
|
|
+ ' Dest.values[','S] := D.ReplaceStrings(IncludeTrailin'+
|
|
|
+ 'gPathDelimiter(TConditionalDestString(c).DestPath)+APrefix+ExtractFile'+
|
|
|
+ 'Name(C.Value));'#013#010+
|
|
|
+ ' end'#013#010+
|
|
|
+ ' else'#013#010+
|
|
|
+ ' Dest.Add(S);'#013#010+
|
|
|
+ ' Inc(Result);'#013#010+
|
|
|
+ ' end;'#013#010+
|
|
|
+ ' en','d;'#013#010+
|
|
|
+ ' finally'#013#010+
|
|
|
+ ' D.Free;'#013#010+
|
|
|
+ ' end;'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ #013#010+
|
|
|
+ 'function FileListToString(List : TStrings; const APrefix : String) : S'+
|
|
|
+ 'tring;'#013#010+
|
|
|
+ 'Var'#013#010+
|
|
|
+ ' I : integer;'#013#010+
|
|
|
+ ' S : String;'#013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' Result:='#039#039';'#013#010+
|
|
|
+ ' For I:=0 to List.Count-1 do'#013#010+
|
|
|
+ ' begin'#013#010+
|
|
|
+ ' If (I>0) t','hen'#013#010+
|
|
|
+ ' Result:=Result+'#039' '#039';'#013#010+
|
|
|
+ ' S:=APrefix+List[i];'#013#010+
|
|
|
+ ' If (Pos('#039' '#039',S)<>0) then'#013#010+
|
|
|
+ ' S:='#039'"'#039'+S+'#039'"'#039';'#013#010+
|
|
|
+ ' Result:=Result+S;'#013#010+
|
|
|
+ ' end;'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ #013#010+
|
|
|
+ 'function FixPath (const APath : String) : String;'#013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' Result := FixPath(AP','ath, False);'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ 'function FixPath (const APath : String; AIsDir : Boolean) : String;'#013+
|
|
|
+ #010+
|
|
|
+ 'Var'#013#010+
|
|
|
+ ' P : PChar;'#013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' Result:=APath;'#013#010+
|
|
|
+ ' If (result<>'#039#039') then'#013#010+
|
|
|
+ ' begin'#013#010+
|
|
|
+ ' UniqueString(Result);'#013#010+
|
|
|
+ ' P:=PChar(Result);'#013#010+
|
|
|
+ ' While (P^<','>#0) do'#013#010+
|
|
|
+ ' begin'#013#010+
|
|
|
+ ' If P^ in ['#039'/'#039','#039'\'#039'] then'#013#010+
|
|
|
+ ' P^:=PathDelim;'#013#010+
|
|
|
+ ' Inc(P);'#013#010+
|
|
|
+ ' end;'#013#010+
|
|
|
+ ' end;'#013#010+
|
|
|
+ ' if AIsDir and (Result <> '#039#039') then'#013#010+
|
|
|
+ ' Result := IncludeTrailingPathDelimiter(Result);;'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ 'function Is','RelativePath(const APath: String): boolean;'#013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' if APath='#039#039' then'#013#010+
|
|
|
+ ' result := true'#013#010+
|
|
|
+ '{$ifdef unix}'#013#010+
|
|
|
+ ' else if APath[1] in AllowDirectorySeparators then'#013#010+
|
|
|
+ ' result := false'#013#010+
|
|
|
+ '{$else}'#013#010+
|
|
|
+ ' else if ExtractFileDrive(APath)<>'#039#039' then'#013#010+
|
|
|
+ ' re','sult := false'#013#010+
|
|
|
+ '{$endif}'#013#010+
|
|
|
+ ' else'#013#010+
|
|
|
+ ' result := true;'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ 'procedure ChangeDir(const APath : String);'#013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' if Not SetCurrentDir(APath) then'#013#010+
|
|
|
+ ' Raise EInstallerError.CreateFmt(SErrChangeDirFailed,[APath]);'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ #013#010+
|
|
|
+ 'procedure Sear','chFiles(const AFileName: string; Recursive: boolean; v'+
|
|
|
+ 'ar List: TStrings);'#013#010+
|
|
|
+ #013#010+
|
|
|
' procedure AddRecursiveFiles(const SearchDir, FileMask: string; Recur'+
|
|
|
- 'sive: ','boolean);'#010+
|
|
|
- ' var'#010+
|
|
|
- ' Info : TSearchRec;'#010+
|
|
|
- ' begin'#010+
|
|
|
- ' if FindFirst(SearchDir+AllFilesMask,faAnyFile and faDirectory,Info'+
|
|
|
- ')=0 then'#010+
|
|
|
- ' begin'#010+
|
|
|
- ' repeat'#010+
|
|
|
+ 'sive: boolean);'#013#010+
|
|
|
+ ' var'#013#010+
|
|
|
+ ' Info : TSearchRec;'#013#010+
|
|
|
+ ' begin'#013#010+
|
|
|
+ ' if FindFirst(SearchDir+AllFilesM','ask,faAnyFile and faDirectory,In'+
|
|
|
+ 'fo)=0 then'#013#010+
|
|
|
+ ' begin'#013#010+
|
|
|
+ ' repeat'#013#010+
|
|
|
' if ((Info.Attr and faDirectory) = faDirectory) and (Info.Nam'+
|
|
|
- 'e <> '#039'.'#039') and (Info.N','ame <> '#039'..'#039') and (Recursive) th'+
|
|
|
- 'en'#010+
|
|
|
- ' AddRecursiveFiles(SearchDir + Info.Name + PathDelim, FileM'+
|
|
|
- 'ask, Recursive);'#010+
|
|
|
+ 'e <> '#039'.'#039') and (Info.Name <> '#039'..'#039') and (Recursive) then'+
|
|
|
+ #013#010+
|
|
|
+ ' AddRecursiveFiles(SearchDir + Inf','o.Name + PathDelim, Fil'+
|
|
|
+ 'eMask, Recursive);'#013#010+
|
|
|
' if ((Info.Attr and faDirectory) <> faDirectory) and IsWild(I'+
|
|
|
- 'nfo.Name, FileMask, FileNameCaseSensitive) then'#010+
|
|
|
- ' ',' List.Add(SearchDir + Info.Name);'#010+
|
|
|
- ' until FindNext(Info)<>0;'#010+
|
|
|
- ' end;'#010+
|
|
|
- ' FindClose(Info);'#010+
|
|
|
- ' end;'#010+
|
|
|
- #010+
|
|
|
- 'var'#010+
|
|
|
- ' CurrDir,'#010+
|
|
|
- ' BasePath: string;'#010+
|
|
|
- ' i: integer;'#010+
|
|
|
- 'begin'#010+
|
|
|
- ' BasePath := ExtractFilePath(ExpandFileName(AFileName));'#010+
|
|
|
- ' AddRecursive','Files(BasePath, ExtractFileName(AFileName), Recursive)'+
|
|
|
- ';'#010+
|
|
|
- #010+
|
|
|
- ' CurrDir:=GetCurrentDir;'#010+
|
|
|
- ' for i := 0 to Pred(List.Count) do'#010+
|
|
|
+ 'nfo.Name, FileMask, FileNameCaseSensitive) then'#013#010+
|
|
|
+ ' List.Add(SearchDir + Info.Name);'#013#010+
|
|
|
+ ' until FindNext(Info)<>0;'#013#010,
|
|
|
+ ' end;'#013#010+
|
|
|
+ ' FindClose(Info);'#013#010+
|
|
|
+ ' end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ 'var'#013#010+
|
|
|
+ ' CurrDir,'#013#010+
|
|
|
+ ' BasePath: string;'#013#010+
|
|
|
+ ' i: integer;'#013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' BasePath := ExtractFilePath(ExpandFileName(AFileName));'#013#010+
|
|
|
+ ' AddRecursiveFiles(BasePath, ExtractFileName(AFileName), Recursive);'#013+
|
|
|
+ #010+
|
|
|
+ #013#010+
|
|
|
+ ' Curr','Dir:=GetCurrentDir;'#013#010+
|
|
|
+ ' for i := 0 to Pred(List.Count) do'#013#010+
|
|
|
' List[i] := ExtractRelativepath(IncludeTrailingPathDelimiter(CurrDi'+
|
|
|
- 'r), List[i]);'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
- 'Const'#010+
|
|
|
- ' WhiteSpace = [#9,#10,#1','3,'#039' '#039'];'#010+
|
|
|
- ' QuoteChars = ['#039#039#039#039','#039'"'#039'];'#010+
|
|
|
- #010+
|
|
|
- 'procedure SplitCommand(const Cmd : String; var Exe, Options : String);'+
|
|
|
- #010+
|
|
|
- #010+
|
|
|
- 'Var'#010+
|
|
|
- ' I : Integer;'#010+
|
|
|
- ' InQuote : Boolean;'#010+
|
|
|
- ' LastQuote : Char;'#010+
|
|
|
- ' S : String;'#010+
|
|
|
- #010+
|
|
|
- 'begin'#010+
|
|
|
- ' S:=Trim(Cmd);'#010+
|
|
|
- ' InQuote:=False;'#010+
|
|
|
- ' LastQuote:=#0;'#010,
|
|
|
- ' I:=1;'#010+
|
|
|
- ' While (I<=Length(S)) and (Inquote or not (S[I] in whiteSpace)) do'#010+
|
|
|
- ' begin'#010+
|
|
|
- ' If S[i] in QuoteChars then'#010+
|
|
|
- ' begin'#010+
|
|
|
- ' InQuote:=Not (S[i]=LastQuote);'#010+
|
|
|
- ' If InQuote then'#010+
|
|
|
- ' LastQuote:=S[i]'#010+
|
|
|
- ' else'#010+
|
|
|
- ' LastQu','ote:=#0;'#010+
|
|
|
- ' end;'#010+
|
|
|
- ' Inc(I);'#010+
|
|
|
- ' end;'#010+
|
|
|
- ' Exe:=Copy(S,1,I-1);'#010+
|
|
|
- ' Delete(S,1,I);'#010+
|
|
|
- ' Options:=Trim(S);'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
+ 'r), List[i]);'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ 'Const'#013#010+
|
|
|
+ ' WhiteSpace = [#9,#10,#13,'#039' '#039'];'#013#010+
|
|
|
+ ' QuoteChars = ['#039#039#039#039','#039'"'#039'];'#013#010+
|
|
|
+ #013#010+
|
|
|
+ 'procedure SplitCom','mand(const Cmd : String; var Exe, Options : String'+
|
|
|
+ ');'#013#010+
|
|
|
+ #013#010+
|
|
|
+ 'Var'#013#010+
|
|
|
+ ' I : Integer;'#013#010+
|
|
|
+ ' InQuote : Boolean;'#013#010+
|
|
|
+ ' LastQuote : Char;'#013#010+
|
|
|
+ ' S : String;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' S:=Trim(Cmd);'#013#010+
|
|
|
+ ' InQuote:=False;'#013#010+
|
|
|
+ ' LastQuote:=#0;'#013#010+
|
|
|
+ ' I:=1;'#013#010+
|
|
|
+ ' While (I<=Length(S)) and (Inquo','te or not (S[I] in whiteSpace)) do'#013+
|
|
|
+ #010+
|
|
|
+ ' begin'#013#010+
|
|
|
+ ' If S[i] in QuoteChars then'#013#010+
|
|
|
+ ' begin'#013#010+
|
|
|
+ ' InQuote:=Not (S[i]=LastQuote);'#013#010+
|
|
|
+ ' If InQuote then'#013#010+
|
|
|
+ ' LastQuote:=S[i]'#013#010+
|
|
|
+ ' else'#013#010+
|
|
|
+ ' LastQuote:=#0;'#013#010+
|
|
|
+ ' end;'#013#010+
|
|
|
+ ' Inc(I);',#013#010+
|
|
|
+ ' end;'#013#010+
|
|
|
+ ' Exe:=Copy(S,1,I-1);'#013#010+
|
|
|
+ ' Delete(S,1,I);'#013#010+
|
|
|
+ ' Options:=Trim(S);'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
'procedure AddCustomFpmakeCommandlineOption(const ACommandLineOption, H'+
|
|
|
- 'elpMessage : string);'#010+
|
|
|
- 'begin'#010+
|
|
|
- ' if not assigned(CustomFpmakeComman','dlineOptions) then'#010+
|
|
|
- ' CustomFpmakeCommandlineOptions := TStringList.Create;'#010+
|
|
|
+ 'elpMessage : string);'#013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' if not assigned(CustomFpmakeCommandlineOptions) then'#013#010+
|
|
|
+ ' ',' CustomFpmakeCommandlineOptions := TStringList.Create;'#013#010+
|
|
|
' CustomFpmakeCommandlineOptions.Values[ACommandLineOption]:=HelpMessa'+
|
|
|
- 'ge;'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
+ 'ge;'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
'function GetCustomFpmakeCommandlineOptionValue(const ACommandLineOptio'+
|
|
|
- 'n: string): s','tring;'#010+
|
|
|
- 'begin'#010+
|
|
|
- ' if not assigned(CustomFpMakeCommandlineValues) then'#010+
|
|
|
- ' result := '#039#039#010+
|
|
|
- ' else'#010+
|
|
|
+ 'n: string): string;'#013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' ','if not assigned(CustomFpMakeCommandlineValues) then'#013#010+
|
|
|
+ ' result := '#039#039#013#010+
|
|
|
+ ' else'#013#010+
|
|
|
' result := CustomFpMakeCommandlineValues.Values[ACommandLineOption]'+
|
|
|
- ';'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
+ ';'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
'function AddProgramExtension(const ExecutableName: string; AOS : TOS):'+
|
|
|
- ' ','string;'#010+
|
|
|
- 'begin'#010+
|
|
|
- ' if AOS in [Go32v2,Win32,Win64,Wince,OS2,EMX,Watcom] then'#010+
|
|
|
- ' Result:=ExecutableName+ExeExt'#010+
|
|
|
- ' else'#010+
|
|
|
- ' Result:=ExecutableName;'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
+ ' string;'#013#010,
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' if AOS in [Go32v2,Win32,Win64,Wince,OS2,EMX,Watcom] then'#013#010+
|
|
|
+ ' Result:=ExecutableName+ExeExt'#013#010+
|
|
|
+ ' else'#013#010+
|
|
|
+ ' Result:=ExecutableName;'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
'function GetImportLibraryFilename(const UnitName: string; AOS: TOS): s'+
|
|
|
- 'tring;'#010+
|
|
|
- 'begin'#010+
|
|
|
- ' if AOS ','in [go32v2,watcom,os2,emx] then'#010+
|
|
|
- ' Result := '#039'libimp'#039'+UnitName'#010+
|
|
|
- ' else if AOS in [netware,netwlibc,macos] then'#010+
|
|
|
- ' Result := '#039'lib'#039'+UnitName'#010+
|
|
|
- ' else'#010+
|
|
|
- ' Result := '#039'libimp'#039'+UnitName;'#010+
|
|
|
- ' Result := Result + LibExt;'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
- 'Function OptionListToStri','ng(L : TStrings) : String;'#010+
|
|
|
- #010+
|
|
|
- 'var'#010+
|
|
|
- ' I : Integer;'#010+
|
|
|
- ' S : String;'#010+
|
|
|
- #010+
|
|
|
- 'begin'#010+
|
|
|
- ' Result:='#039#039';'#010+
|
|
|
- ' For I:=0 to L.Count-1 do'#010+
|
|
|
- ' begin'#010+
|
|
|
- ' If (Result<>'#039#039') then'#010+
|
|
|
- ' Result:=Result+'#039' '#039';'#010+
|
|
|
- ' S:=L[I];'#010+
|
|
|
- ' If (Pos('#039' '#039',S)<>0) or (S='#039#039') then'#010+
|
|
|
- ' Result:= Resu','lt + '#039'"'#039'+S+'#039'"'#039#010+
|
|
|
- ' else'#010+
|
|
|
- ' Result:= Result + S;'#010+
|
|
|
- ' end;'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
- 'Function OptionsToStringList(S : String) : TStrings;'#010+
|
|
|
- #010+
|
|
|
- 'Var'#010+
|
|
|
- ' P : Integer;'#010+
|
|
|
- #010+
|
|
|
- 'begin'#010+
|
|
|
- ' Result:=Nil;'#010+
|
|
|
- ' If (S='#039#039') then'#010+
|
|
|
- ' Exit;'#010+
|
|
|
- ' Result:=TStringList.Create;'#010+
|
|
|
- ' Repeat'#010+
|
|
|
- ' P:=Pos('#039' ',#039',S);'#010+
|
|
|
- ' If P=0 then'#010+
|
|
|
- ' P:=Length(S)+1;'#010+
|
|
|
- ' Result.Add(Copy(S,1,P-1));'#010+
|
|
|
- ' Delete(S,1,P);'#010+
|
|
|
- ' S:=Trim(S);'#010+
|
|
|
- ' Until Length(S)=0;'#010+
|
|
|
- ' If Result.Count=0 then'#010+
|
|
|
- ' FreeAndNil(Result);'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
- #010+
|
|
|
- '{$ifdef HAS_UNIT_PROCESS}'#010+
|
|
|
- 'function GetCompilerInfo(co','nst ACompiler,AOptions:string):string;'#010+
|
|
|
- 'const'#010+
|
|
|
- ' BufSize = 1024;'#010+
|
|
|
- 'var'#010+
|
|
|
- ' S: TProcess;'#010+
|
|
|
- ' Buf: array [0..BufSize - 1] of char;'#010+
|
|
|
- ' Count: longint;'#010+
|
|
|
- 'begin'#010+
|
|
|
- ' S:=TProcess.Create(Nil);'#010+
|
|
|
- ' S.Commandline:=ACompiler+'#039' '#039'+AOptions;'#010+
|
|
|
- ' S.Options:=[poUsePipes];'#010,
|
|
|
- ' S.execute;'#010+
|
|
|
- ' Count:=s.output.read(buf,BufSize);'#010+
|
|
|
- ' S.Free;'#010+
|
|
|
- ' SetLength(Result,Count);'#010+
|
|
|
- ' Move(Buf,Result[1],Count);'#010+
|
|
|
- 'end;'#010+
|
|
|
- '{$endif HAS_UNIT_PROCESS}'#010+
|
|
|
- #010+
|
|
|
- 'constructor TPackageVariant.Create(ACollection: TCollection);'#010+
|
|
|
- 'begin'#010+
|
|
|
- ' inherited Create(AColl','ection);'#010+
|
|
|
- ' FTargets := TTargets.Create(TTarget);'#010+
|
|
|
- ' FOptions := TStringList.Create;'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
- 'destructor TPackageVariant.Destroy;'#010+
|
|
|
- 'begin'#010+
|
|
|
- ' FOptions.Free;'#010+
|
|
|
- ' FTargets.Free;'#010+
|
|
|
- ' inherited Destroy;'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
- '{ TPackageVariants }'#010+
|
|
|
- #010+
|
|
|
- 'procedure TPackageVariants','.SetDefaultPackageVariantName(AValue: stri'+
|
|
|
- 'ng);'#010+
|
|
|
- 'begin'#010+
|
|
|
- ' if FDefaultPackageVariantName=AValue then Exit;'#010+
|
|
|
- ' if not assigned(ItemByName(avalue)) then'#010+
|
|
|
- ' raise exception.CreateFmt(SErrPackVarNotExist,[AValue]);'#010+
|
|
|
- ' FDefaultPackageVariantName:=AVa','lue;'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
- 'function TPackageVariants.GetActivePackageVariant: TPackageVariant;'#010+
|
|
|
- 'begin'#010+
|
|
|
- ' result := ItemByName(ActivePackageVariantName) as TPackageVariant;'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
- 'function TPackageVariants.GetDefaultPackageVariant: TPackageVariant;'#010+
|
|
|
- 'begin'#010+
|
|
|
- ' res','ult := ItemByName(DefaultPackageVariantName) as TPackageVariant'+
|
|
|
- ';'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
- 'procedure TPackageVariants.SetActivePackageVariantName(AValue: string)'+
|
|
|
- ';'#010+
|
|
|
- 'begin'#010+
|
|
|
- ' if FActivePackageVariantName=AValue then Exit;'#010+
|
|
|
- ' if not assigned(ItemByName(avalue)) then',#010+
|
|
|
- ' raise exception.CreateFmt(SErrPackVarNotExist,[AValue]);'#010+
|
|
|
- ' FActivePackageVariantName:=AValue;'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
- 'function TPackageVariants.Add(AName: String): TPackageVariant;'#010+
|
|
|
- 'begin'#010+
|
|
|
- ' result := self.add as TPackageVariant;'#010+
|
|
|
- ' result.Name := AName;'#010+
|
|
|
- ' ',' if FDefaultPackageVariantName='#039#039' then'#010+
|
|
|
- ' FDefaultPackageVariantName:=AName;'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
- #010+
|
|
|
- '{ TConditionalDestStrings }'#010+
|
|
|
- #010+
|
|
|
+ 'tring;'#013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' if AOS',' in [go32v2,watcom,os2,emx] then'#013#010+
|
|
|
+ ' Result := '#039'libimp'#039'+UnitName'#013#010+
|
|
|
+ ' else if AOS in [netware,netwlibc,macos] then'#013#010+
|
|
|
+ ' Result := '#039'lib'#039'+UnitName'#013#010+
|
|
|
+ ' else'#013#010+
|
|
|
+ ' Result := '#039'libimp'#039'+UnitName;'#013#010+
|
|
|
+ ' Result := Result + LibExt;'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ 'Function Option','ListToString(L : TStrings) : String;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ 'var'#013#010+
|
|
|
+ ' I : Integer;'#013#010+
|
|
|
+ ' S : String;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' Result:='#039#039';'#013#010+
|
|
|
+ ' For I:=0 to L.Count-1 do'#013#010+
|
|
|
+ ' begin'#013#010+
|
|
|
+ ' If (Result<>'#039#039') then'#013#010+
|
|
|
+ ' Result:=Result+'#039' '#039';'#013#010+
|
|
|
+ ' S:=L[I];'#013#010+
|
|
|
+ ' If (Pos('#039' '#039',S)<>0) or (S='#039#039') t','hen'#013#010+
|
|
|
+ ' Result:= Result + '#039'"'#039'+S+'#039'"'#039#013#010+
|
|
|
+ ' else'#013#010+
|
|
|
+ ' Result:= Result + S;'#013#010+
|
|
|
+ ' end;'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ 'Function OptionsToStringList(S : String) : TStrings;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ 'Var'#013#010+
|
|
|
+ ' P : Integer;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' Result:=Nil;'#013#010+
|
|
|
+ ' If (S='#039#039') then'#013#010+
|
|
|
+ ' Exit;'#013#010+
|
|
|
+ ' Result:=TSt','ringList.Create;'#013#010+
|
|
|
+ ' Repeat'#013#010+
|
|
|
+ ' P:=Pos('#039' '#039',S);'#013#010+
|
|
|
+ ' If P=0 then'#013#010+
|
|
|
+ ' P:=Length(S)+1;'#013#010+
|
|
|
+ ' Result.Add(Copy(S,1,P-1));'#013#010+
|
|
|
+ ' Delete(S,1,P);'#013#010+
|
|
|
+ ' S:=Trim(S);'#013#010+
|
|
|
+ ' Until Length(S)=0;'#013#010+
|
|
|
+ ' If Result.Count=0 then'#013#010+
|
|
|
+ ' FreeAndNil(Result);'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ #013#010,
|
|
|
+ '{$ifdef HAS_UNIT_PROCESS}'#013#010+
|
|
|
+ 'function GetCompilerInfo(const ACompiler,AOptions:string):string;'#013#010+
|
|
|
+ 'const'#013#010+
|
|
|
+ ' BufSize = 1024;'#013#010+
|
|
|
+ 'var'#013#010+
|
|
|
+ ' S: TProcess;'#013#010+
|
|
|
+ ' Buf: array [0..BufSize - 1] of char;'#013#010+
|
|
|
+ ' Count: longint;'#013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' S:=TProcess.Create(Nil);'#013#010+
|
|
|
+ ' S.C','ommandline:=ACompiler+'#039' '#039'+AOptions;'#013#010+
|
|
|
+ ' S.Options:=[poUsePipes];'#013#010+
|
|
|
+ ' S.execute;'#013#010+
|
|
|
+ ' Count:=s.output.read(buf,BufSize);'#013#010+
|
|
|
+ ' S.Free;'#013#010+
|
|
|
+ ' SetLength(Result,Count);'#013#010+
|
|
|
+ ' Move(Buf,Result[1],Count);'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ '{$endif HAS_UNIT_PROCESS}'#013#010+
|
|
|
+ #013#010+
|
|
|
+ 'constructor TPackag','eVariant.Create(ACollection: TCollection);'#013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' inherited Create(ACollection);'#013#010+
|
|
|
+ ' FTargets := TTargets.Create(TTarget);'#013#010+
|
|
|
+ ' FOptions := TStringList.Create;'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ 'destructor TPackageVariant.Destroy;'#013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' FOptions.Free;'#013#010+
|
|
|
+ ' FTarget','s.Free;'#013#010+
|
|
|
+ ' inherited Destroy;'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ '{ TPackageVariants }'#013#010+
|
|
|
+ #013#010+
|
|
|
+ 'procedure TPackageVariants.SetDefaultPackageVariantName(AValue: string'+
|
|
|
+ ');'#013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' if FDefaultPackageVariantName=AValue then Exit;'#013#010+
|
|
|
+ ' if not assigned(ItemByName(avalue)) then'#013#010+
|
|
|
+ ' ',' raise exception.CreateFmt(SErrPackVarNotExist,[AValue]);'#013#010+
|
|
|
+ ' FDefaultPackageVariantName:=AValue;'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ 'function TPackageVariants.GetActivePackageVariant: TPackageVariant;'#013+
|
|
|
+ #010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' result := ItemByName(ActivePackageVariantName) as TPac','kageVariant;'+
|
|
|
+ #013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ 'function TPackageVariants.GetDefaultPackageVariant: TPackageVariant;'#013+
|
|
|
+ #010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' result := ItemByName(DefaultPackageVariantName) as TPackageVariant;'#013+
|
|
|
+ #010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ 'procedure TPackageVariants.SetActivePackageVariantName(AValue:',' strin'+
|
|
|
+ 'g);'#013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' if FActivePackageVariantName=AValue then Exit;'#013#010+
|
|
|
+ ' if not assigned(ItemByName(avalue)) then'#013#010+
|
|
|
+ ' raise exception.CreateFmt(SErrPackVarNotExist,[AValue]);'#013#010+
|
|
|
+ ' FActivePackageVariantName:=AValue;'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ 'function TPackageVar','iants.Add(AName: String): TPackageVariant;'#013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' result := self.add as TPackageVariant;'#013#010+
|
|
|
+ ' result.Name := AName;'#013#010+
|
|
|
+ ' if FDefaultPackageVariantName='#039#039' then'#013#010+
|
|
|
+ ' FDefaultPackageVariantName:=AName;'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ #013#010+
|
|
|
+ '{ TConditionalDestStrings }'#013#010+
|
|
|
+ #013#010,
|
|
|
'function TConditionalDestStrings.GetConditionalString(Index : Integer)'+
|
|
|
- ': TConditionalDestString;'#010+
|
|
|
- 'begin'#010+
|
|
|
- ' Result:=TConditionalDe','stString(Items[Index]);'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
+ ': TConditionalDestString;'#013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' Result:=TConditionalDestString(Items[Index]);'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
'procedure TConditionalDestStrings.SetConditionalString(Index : Integer'+
|
|
|
- '; AValue: TConditionalDestString);'#010+
|
|
|
- 'begin'#010+
|
|
|
- ' Items[Index]:=AValue;'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
- 'constructor TConditionalDestStrings.Create(AClass: TConditionalDestSt',
|
|
|
- 'ringClass);'#010+
|
|
|
- 'begin'#010+
|
|
|
- ' inherited Create(AClass);'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
- 'function TConditionalDestStrings.Add(const Value: String; ADestPath: S'+
|
|
|
- 'tring): TConditionalDestString;'#010+
|
|
|
- 'begin'#010+
|
|
|
- ' Add(Value, AllCPUs, AllOSes, ADestPath);'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
- 'function TConditionalDestString','s.Add(const Value: String; const OSes'+
|
|
|
- ': TOSes; ADestPath: String): TConditionalDestString;'#010+
|
|
|
- 'begin'#010+
|
|
|
- ' Add(Value, AllCPUs, OSes, ADestPath);'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
- '{$ifdef cpu_only_overloads}'#010+
|
|
|
- 'Function TConditionalDestStrings.Add(Const Value : String;const CPUs:T',
|
|
|
- 'CPUs; ADestPath: String) : TConditionalDestString;inline;'#010+
|
|
|
- 'begin'#010+
|
|
|
- ' Add(Value, CPUs, AllOSes, ADestPath);'#010+
|
|
|
- 'end;'#010+
|
|
|
- '{$endif cpu_only_overloads}'#010+
|
|
|
- #010+
|
|
|
- #010+
|
|
|
+ '; AValue:',' TConditionalDestString);'#013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' Items[Index]:=AValue;'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ 'constructor TConditionalDestStrings.Create(AClass: TConditionalDestStr'+
|
|
|
+ 'ingClass);'#013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' inherited Create(AClass);'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ 'function TConditionalDestStrings.Add(const Valu','e: String; ADestPath:'+
|
|
|
+ ' String): TConditionalDestString;'#013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' Add(Value, AllCPUs, AllOSes, ADestPath);'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ 'function TConditionalDestStrings.Add(const Value: String; const OSes: '+
|
|
|
+ 'TOSes; ADestPath: String): TConditionalDestString;'#013#010+
|
|
|
+ 'beg','in'#013#010+
|
|
|
+ ' Add(Value, AllCPUs, OSes, ADestPath);'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ '{$ifdef cpu_only_overloads}'#013#010+
|
|
|
+ 'Function TConditionalDestStrings.Add(Const Value : String;const CPUs:T'+
|
|
|
+ 'CPUs; ADestPath: String) : TConditionalDestString;inline;'#013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' Add(Value, CPUs, All','OSes, ADestPath);'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ '{$endif cpu_only_overloads}'#013#010+
|
|
|
+ #013#010+
|
|
|
+ #013#010+
|
|
|
'function TConditionalDestStrings.Add(const Value: String; const CPUs: '+
|
|
|
- 'TCPUs; const OSes: TOSes; ADest','Path: String): TConditionalDestString'+
|
|
|
- ';'#010+
|
|
|
- 'var'#010+
|
|
|
- ' ACondString: TConditionalDestString;'#010+
|
|
|
- 'begin'#010+
|
|
|
- ' ACondString := inherited Add(Value,CPUs,OSes) as TConditionalDestStr'+
|
|
|
- 'ing;'#010+
|
|
|
- ' ACondString.DestPath:=ADestPath;'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
- '{ TPackageDictionary }'#010+
|
|
|
- #010+
|
|
|
- 'function TPa','ckageDictionary.GetValue(const AName, Args: String): Str'+
|
|
|
- 'ing;'#010+
|
|
|
- 'Var'#010+
|
|
|
- ' O : TObject;'#010+
|
|
|
- ' I : Integer;'#010+
|
|
|
- 'begin'#010+
|
|
|
- ' I:=Flist.IndexOf(AName);'#010+
|
|
|
- ' If (I=-1) then'#010+
|
|
|
- ' begin'#010+
|
|
|
- ' if assigned(MasterDictionary) then'#010+
|
|
|
- ' result := MasterDictionary.GetValue(','AName,Args)'#010+
|
|
|
- ' else'#010+
|
|
|
- ' result := GlobalDictionary.GetValue(AName,Args);'#010+
|
|
|
- ' Exit;'#010+
|
|
|
- ' end;'#010+
|
|
|
- ' O:=Flist.Objects[I];'#010+
|
|
|
- ' If O is TValueItem then'#010+
|
|
|
- ' Result:=TValueItem(O).FValue'#010+
|
|
|
- ' else'#010+
|
|
|
- ' Result:=TFunctionItem(O).FFunc(AName,Args);'#010+
|
|
|
- 'en','d;'#010+
|
|
|
- #010+
|
|
|
- '{$ifndef NO_THREADING}'#010+
|
|
|
- #010+
|
|
|
- '{ TCompileWorkerThread }'#010+
|
|
|
+ 'TCPUs; const OSes: TOSes; ADestPath: String): TConditionalDestString;'#013+
|
|
|
#010+
|
|
|
+ 'var'#013#010+
|
|
|
+ ' ACondString: TConditionalDestStrin','g;'#013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' ACondString := inherited Add(Value,CPUs,OSes) as TConditionalDestStr'+
|
|
|
+ 'ing;'#013#010+
|
|
|
+ ' ACondString.DestPath:=ADestPath;'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ '{ TPackageDictionary }'#013#010+
|
|
|
+ #013#010+
|
|
|
+ 'function TPackageDictionary.GetValue(const AName, Args: String): Strin'+
|
|
|
+ 'g;'#013#010+
|
|
|
+ 'Var'#013#010+
|
|
|
+ ' O ',': TObject;'#013#010+
|
|
|
+ ' I : Integer;'#013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' I:=Flist.IndexOf(AName);'#013#010+
|
|
|
+ ' If (I=-1) then'#013#010+
|
|
|
+ ' begin'#013#010+
|
|
|
+ ' if assigned(MasterDictionary) then'#013#010+
|
|
|
+ ' result := MasterDictionary.GetValue(AName,Args)'#013#010+
|
|
|
+ ' else'#013#010+
|
|
|
+ ' result := GlobalDictionary.Ge','tValue(AName,Args);'#013#010+
|
|
|
+ ' Exit;'#013#010+
|
|
|
+ ' end;'#013#010+
|
|
|
+ ' O:=Flist.Objects[I];'#013#010+
|
|
|
+ ' If O is TValueItem then'#013#010+
|
|
|
+ ' Result:=TValueItem(O).FValue'#013#010+
|
|
|
+ ' else'#013#010+
|
|
|
+ ' Result:=TFunctionItem(O).FFunc(AName,Args);'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ '{$ifndef NO_THREADING}'#013#010+
|
|
|
+ #013#010+
|
|
|
+ '{ TCompileWorkerThre','ad }'#013#010+
|
|
|
+ #013#010+
|
|
|
'constructor TCompileWorkerThread.Create(ABuildEngine: TBuildEngine; No'+
|
|
|
- 'tifyMainThreadEvent: PRTLEvent);'#010+
|
|
|
- 'begin'#010+
|
|
|
- ' inherited Create(false);'#010+
|
|
|
- ' FNotifyStartTask := RTLEventCreate;'#010+
|
|
|
- ' FBuildEngi','ne := ABuildEngine;'#010+
|
|
|
- ' FNotifyMainThreadEvent:=NotifyMainThreadEvent;'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
- 'destructor TCompileWorkerThread.Destroy;'#010+
|
|
|
- 'begin'#010+
|
|
|
- ' RTLeventdestroy(FNotifyStartTask);'#010+
|
|
|
- ' inherited Destroy;'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
- 'procedure TCompileWorkerThread.execute;'#010+
|
|
|
- 'begin'#010+
|
|
|
- ' while ','not Terminated do'#010+
|
|
|
- ' begin'#010+
|
|
|
- ' FDone:=true;'#010+
|
|
|
- ' RTLeventSetEvent(FNotifyMainThreadEvent);'#010+
|
|
|
- ' RTLeventWaitFor(FNotifyStartTask,500);'#010+
|
|
|
- ' if not FDone then'#010+
|
|
|
- ' begin'#010+
|
|
|
- ' FBuildEngine.log(vlInfo,'#039'Compiling: '#039'+APackage.Name);'#010+
|
|
|
- ' FCompi','lationOK:=false;'#010+
|
|
|
- ' try'#010+
|
|
|
- ' FBuildEngine.Compile(APackage);'#010+
|
|
|
- ' FCompilationOK:=true;'#010+
|
|
|
- ' except'#010+
|
|
|
- ' on E: Exception do'#010+
|
|
|
- ' FErrorMessage := E.Message;'#010+
|
|
|
- ' end;'#010+
|
|
|
- ' end;'#010+
|
|
|
- ' end;'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
- '{$endif NO_THREADING}'#010+
|
|
|
- #010+
|
|
|
- '{****','***************************************************************'+
|
|
|
- '*********'#010+
|
|
|
- ' TUnsortedDuplicatesStringList'#010+
|
|
|
+ 'tifyMainThreadEvent: PRTLEvent);'#013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' inherited Create(false);'#013#010+
|
|
|
+ ' FNotifyStartTask := RTLEventCreate;'#013#010+
|
|
|
+ ' FBuildEngine := ABuildEngine;'#013#010+
|
|
|
+ ' FNotifyMainThreadEv','ent:=NotifyMainThreadEvent;'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ 'destructor TCompileWorkerThread.Destroy;'#013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' RTLeventdestroy(FNotifyStartTask);'#013#010+
|
|
|
+ ' inherited Destroy;'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ 'procedure TCompileWorkerThread.execute;'#013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' while not Terminated do'#013#010+
|
|
|
+ ' begin'#013#010,
|
|
|
+ ' FDone:=true;'#013#010+
|
|
|
+ ' RTLeventSetEvent(FNotifyMainThreadEvent);'#013#010+
|
|
|
+ ' RTLeventWaitFor(FNotifyStartTask,500);'#013#010+
|
|
|
+ ' if not FDone then'#013#010+
|
|
|
+ ' begin'#013#010+
|
|
|
+ ' FBuildEngine.log(vlInfo,'#039'Compiling: '#039'+APackage.Name);'#013+
|
|
|
+ #010+
|
|
|
+ ' FCompilationOK:=false;'#013#010+
|
|
|
+ ' ',' try'#013#010+
|
|
|
+ ' FBuildEngine.Compile(APackage);'#013#010+
|
|
|
+ ' FCompilationOK:=true;'#013#010+
|
|
|
+ ' except'#013#010+
|
|
|
+ ' on E: Exception do'#013#010+
|
|
|
+ ' FErrorMessage := E.Message;'#013#010+
|
|
|
+ ' end;'#013#010+
|
|
|
+ ' end;'#013#010+
|
|
|
+ ' end;'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ '{$endif NO_THREADING}'#013#010+
|
|
|
+ #013#010+
|
|
|
+ '{************','*******************************************************'+
|
|
|
+ '*********'#013#010+
|
|
|
+ ' TUnsortedDuplicatesStringList'#013#010+
|
|
|
'**********************************************************************'+
|
|
|
- '******}'#010+
|
|
|
- #010+
|
|
|
- 'function TUnsortedDuplicatesStr','ingList.Add(const S: string): Integer'+
|
|
|
- ';'#010+
|
|
|
- #010+
|
|
|
- 'begin'#010+
|
|
|
- ' result := IndexOf(S);'#010+
|
|
|
- ' If result > -1 then'#010+
|
|
|
- ' Case DUplicates of'#010+
|
|
|
- ' DupIgnore : Exit;'#010+
|
|
|
- ' DupError : Error(SDuplicateString,0)'#010+
|
|
|
- ' end;'#010+
|
|
|
- ' inherited Add(S);'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
- '{**********************','*********************************************'+
|
|
|
- '*********'#010+
|
|
|
- ' TNamedItem'#010+
|
|
|
+ '******}'#013#010+
|
|
|
+ #013#010+
|
|
|
+ 'function TUnsortedDuplicatesStringL','ist.Add(const S: string): Integer'+
|
|
|
+ ';'#013#010+
|
|
|
+ #013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' result := IndexOf(S);'#013#010+
|
|
|
+ ' If result > -1 then'#013#010+
|
|
|
+ ' Case DUplicates of'#013#010+
|
|
|
+ ' DupIgnore : Exit;'#013#010+
|
|
|
+ ' DupError : Error(SDuplicateString,0)'#013#010+
|
|
|
+ ' end;'#013#010+
|
|
|
+ ' inherited Add(S);'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ '{**************','*****************************************************'+
|
|
|
+ '*********'#013#010+
|
|
|
+ ' TNamedItem'#013#010+
|
|
|
'**********************************************************************'+
|
|
|
- '******}'#010+
|
|
|
- #010+
|
|
|
- 'procedure TNamedItem.SetName(const AValue: String);'#010+
|
|
|
- #010+
|
|
|
- 'begin'#010+
|
|
|
- ' if',' FName=AValue then exit;'#010+
|
|
|
- ' With TNamedCollection(Collection) do'#010+
|
|
|
- ' If UniqueNames then'#010+
|
|
|
- ' If (IndexOfName(AVAlue)<>-1) then'#010+
|
|
|
- ' Raise ECollectionError.CreateFmt(SErrNameExists,[AValue]);'#010+
|
|
|
- ' FName:=AValue;'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
- #010+
|
|
|
- '{********************','***********************************************'+
|
|
|
- '*********'#010+
|
|
|
- ' TNamedCollection'#010+
|
|
|
+ '******}'#013#010+
|
|
|
+ #013#010+
|
|
|
+ 'procedure TNamedItem.SetName(const AValue: String);',#013#010+
|
|
|
+ #013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' if FName=AValue then exit;'#013#010+
|
|
|
+ ' With TNamedCollection(Collection) do'#013#010+
|
|
|
+ ' If UniqueNames then'#013#010+
|
|
|
+ ' If (IndexOfName(AVAlue)<>-1) then'#013#010+
|
|
|
+ ' Raise ECollectionError.CreateFmt(SErrNameExists,[AValue]);'#013+
|
|
|
+ #010+
|
|
|
+ ' FName:=AValue;'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013,#010+
|
|
|
+ #013#010+
|
|
|
+ '{*********************************************************************'+
|
|
|
+ '*******'#013#010+
|
|
|
+ ' TNamedCollection'#013#010+
|
|
|
'**********************************************************************'+
|
|
|
- '******}'#010+
|
|
|
- #010+
|
|
|
- 'function TNamedCollection.GetItem(Index: Integer): TNam','edItem;'#010+
|
|
|
- 'begin'#010+
|
|
|
- ' result := TNamedItem(inherited getItem(index));'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
+ '******}'#013#010+
|
|
|
+ #013#010+
|
|
|
+ 'function TNamedCollection.G','etItem(Index: Integer): TNamedItem;'#013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' result := TNamedItem(inherited getItem(index));'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
'procedure TNamedCollection.SetItem(Index: Integer; AValue: TNamedItem)'+
|
|
|
- ';'#010+
|
|
|
- 'begin'#010+
|
|
|
- ' inherited SetItem(Index, AValue);'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
- 'function TNamedCollection.IndexOfName(const AName:',' String): Integer;'+
|
|
|
- #010+
|
|
|
- #010+
|
|
|
- 'begin'#010+
|
|
|
- ' Result:=Count-1;'#010+
|
|
|
+ ';'#013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' inherited SetItem(Index, AValue);'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ 'function TNa','medCollection.IndexOfName(const AName: String): Integer;'+
|
|
|
+ #013#010+
|
|
|
+ #013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' Result:=Count-1;'#013#010+
|
|
|
' While (Result>=0) and (CompareText(TNamedItem(Items[Result]).FName,A'+
|
|
|
- 'Name)<>0) do'#010+
|
|
|
- ' Dec(Result);'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
- 'function TNamedCollection.ItemByName(const AName: String): TNamedItem;'+
|
|
|
- #010+
|
|
|
- #010+
|
|
|
- 'Var'#010+
|
|
|
- ' I : Integer',';'#010+
|
|
|
- #010+
|
|
|
- 'begin'#010+
|
|
|
- ' I:=IndexOfName(AName);'#010+
|
|
|
- ' If (I=-1) Then'#010+
|
|
|
- ' Raise ECollectionError.CreateFmt(SErrNoSuchName,[AName]);'#010+
|
|
|
- ' Result:=TNamedItem(Items[i]);'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
- #010+
|
|
|
- '{*********************************************************************'+
|
|
|
- '*******'#010+
|
|
|
- ' ',' TNamedItemList'#010+
|
|
|
+ 'Name)<>0) do'#013#010+
|
|
|
+ ' Dec(Result);'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ 'function TNamedCollection.ItemByName(const ','AName: String): TNamedIte'+
|
|
|
+ 'm;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ 'Var'#013#010+
|
|
|
+ ' I : Integer;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' I:=IndexOfName(AName);'#013#010+
|
|
|
+ ' If (I=-1) Then'#013#010+
|
|
|
+ ' Raise ECollectionError.CreateFmt(SErrNoSuchName,[AName]);'#013#010+
|
|
|
+ ' Result:=TNamedItem(Items[i]);'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ #013#010+
|
|
|
+ '{****************************','***************************************'+
|
|
|
+ '*********'#013#010+
|
|
|
+ ' TNamedItemList'#013#010+
|
|
|
'**********************************************************************'+
|
|
|
- '******}'#010+
|
|
|
- #010+
|
|
|
- 'function TNamedItemList.GetNamedItem(Index : Integer): TNamedItem;'#010+
|
|
|
- 'begin'#010+
|
|
|
- ' Result:=TNamedItem(Items[Index]);'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
- #010+
|
|
|
- 'procedure T','NamedItemList.SetNamedItem(Index : Integer; const AValue:'+
|
|
|
- ' TNamedItem);'#010+
|
|
|
- 'begin'#010+
|
|
|
- ' Items[Index]:=AValue;'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
- #010+
|
|
|
- 'function TNamedItemList.IndexOfName(const AName: String): Integer;'#010+
|
|
|
- 'begin'#010+
|
|
|
- ' Result:=Count-1;'#010+
|
|
|
- ' While (Result>=0) and (CompareText(Get','NamedItem(Result).Name,AName'+
|
|
|
- ')<>0) do'#010+
|
|
|
- ' Dec(Result);'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
- #010+
|
|
|
- 'function TNamedItemList.ItemByName(const ANAme: String): TNamedItem;'#010+
|
|
|
- 'Var'#010+
|
|
|
- ' I : Integer;'#010+
|
|
|
- 'begin'#010+
|
|
|
- ' I:=IndexOfName(AName);'#010+
|
|
|
- ' If (I=-1) Then'#010+
|
|
|
- ' Raise ECollectionError.CreateFmt(SErrNo','SuchName,[AName]);'#010+
|
|
|
- ' Result:=TNamedItem(Items[i]);'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
- #010+
|
|
|
+ '******}'#013#010+
|
|
|
+ #013#010+
|
|
|
+ 'function TNamedItemList.GetNamedItem(Index : Integer): TNamedIte','m;'#013+
|
|
|
+ #010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' Result:=TNamedItem(Items[Index]);'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ #013#010+
|
|
|
+ 'procedure TNamedItemList.SetNamedItem(Index : Integer; const AValue: T'+
|
|
|
+ 'NamedItem);'#013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' Items[Index]:=AValue;'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ #013#010+
|
|
|
+ 'function TNamedItemList.IndexOfName(const AName: String):',' Integer;'#013+
|
|
|
+ #010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' Result:=Count-1;'#013#010+
|
|
|
+ ' While (Result>=0) and (CompareText(GetNamedItem(Result).Name,AName)<'+
|
|
|
+ '>0) do'#013#010+
|
|
|
+ ' Dec(Result);'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ #013#010+
|
|
|
+ 'function TNamedItemList.ItemByName(const ANAme: String): TNamedItem;'#013+
|
|
|
+ #010+
|
|
|
+ 'Var'#013#010+
|
|
|
+ ' I : Integer;'#013#010+
|
|
|
+ 'begin',#013#010+
|
|
|
+ ' I:=IndexOfName(AName);'#013#010+
|
|
|
+ ' If (I=-1) Then'#013#010+
|
|
|
+ ' Raise ECollectionError.CreateFmt(SErrNoSuchName,[AName]);'#013#010+
|
|
|
+ ' Result:=TNamedItem(Items[i]);'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ #013#010+
|
|
|
'{*********************************************************************'+
|
|
|
- '*******'#010+
|
|
|
- ' TTargets'#010+
|
|
|
- '***************************************************************','*****'+
|
|
|
- '********}'#010+
|
|
|
- #010+
|
|
|
- 'function TTargets.GetTargetItem(Index : Integer): TTarget;'#010+
|
|
|
- 'begin'#010+
|
|
|
- ' Result:=TTarget(Items[Index]);'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
- #010+
|
|
|
- 'function TTargets.GetTarget(const AName : String): TTarget;'#010+
|
|
|
- 'begin'#010+
|
|
|
- ' Result:=TTarget(ItemByName(AName));'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
- #010+
|
|
|
- 'procedur','e TTargets.SetTargetItem(Index : Integer; const AValue: TTar'+
|
|
|
- 'get);'#010+
|
|
|
- 'begin'#010+
|
|
|
- ' Items[Index]:=AValue;'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
- 'function TTargets.AddFPDoc(const AUnitName, AXMLName: String): TTarget'+
|
|
|
- ';'#010+
|
|
|
- 'begin'#010+
|
|
|
- ' Result:=Add as TTarget;'#010+
|
|
|
- ' Result.Name:=AUnitName;'#010+
|
|
|
- ' Result','.XML:=AXMLName;'#010+
|
|
|
- ' Result.TargetType:=ttFPDoc;'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
- 'Function TTargets.AddUnit(Const AUnitName : String) : TTarget;'#010+
|
|
|
- 'begin'#010+
|
|
|
- ' Result:=AddUnit(AUnitName,AllCPUs,AllOSes);'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
- #010+
|
|
|
- 'Function TTargets.AddUnit(Const AUnitName : String;const OSes:TOSe','s)'+
|
|
|
- ' : TTarget;'#010+
|
|
|
- 'begin'#010+
|
|
|
- ' Result:=AddUnit(AUnitName,AllCPUs,OSes);'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
- #010+
|
|
|
- '{$ifdef cpu_only_overloads}'#010+
|
|
|
- 'Function TTargets.AddUnit(Const AUnitName : String;const CPUs:TCPUs) :'+
|
|
|
- ' TTarget;'#010+
|
|
|
- 'begin'#010+
|
|
|
- ' Result:=AddUnit(AUnitName,CPUs,AllOSes);'#010+
|
|
|
- 'end;'#010+
|
|
|
- '{$endif ','cpu_only_overloads}'#010+
|
|
|
- #010+
|
|
|
- #010+
|
|
|
+ '*******'#013#010+
|
|
|
+ ' ',' TTargets'#013#010+
|
|
|
+ '**********************************************************************'+
|
|
|
+ '******}'#013#010+
|
|
|
+ #013#010+
|
|
|
+ 'function TTargets.GetTargetItem(Index : Integer): TTarget;'#013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' Result:=TTarget(Items[Index]);'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ #013#010+
|
|
|
+ 'function TTarge','ts.GetTarget(const AName : String): TTarget;'#013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' Result:=TTarget(ItemByName(AName));'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ #013#010+
|
|
|
+ 'procedure TTargets.SetTargetItem(Index : Integer; const AValue: TTarge'+
|
|
|
+ 't);'#013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' Items[Index]:=AValue;'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ 'function TTargets.AddFP','Doc(const AUnitName, AXMLName: String): TTarg'+
|
|
|
+ 'et;'#013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' Result:=Add as TTarget;'#013#010+
|
|
|
+ ' Result.Name:=AUnitName;'#013#010+
|
|
|
+ ' Result.XML:=AXMLName;'#013#010+
|
|
|
+ ' Result.TargetType:=ttFPDoc;'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ 'Function TTargets.AddUnit(Const AUnitName : String) : TTarget;'#013#010+
|
|
|
+ 'b','egin'#013#010+
|
|
|
+ ' Result:=AddUnit(AUnitName,AllCPUs,AllOSes);'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ #013#010+
|
|
|
+ 'Function TTargets.AddUnit(Const AUnitName : String;const OSes:TOSes) :'+
|
|
|
+ ' TTarget;'#013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' Result:=AddUnit(AUnitName,AllCPUs,OSes);'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ #013#010+
|
|
|
+ '{$ifdef cpu_only_overloads}'#013#010+
|
|
|
+ 'Functi','on TTargets.AddUnit(Const AUnitName : String;const CPUs:TCPUs)'+
|
|
|
+ ' : TTarget;'#013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' Result:=AddUnit(AUnitName,CPUs,AllOSes);'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ '{$endif cpu_only_overloads}'#013#010+
|
|
|
+ #013#010+
|
|
|
+ #013#010+
|
|
|
'Function TTargets.AddUnit(Const AUnitName : String;const CPUs:TCPUs;co'+
|
|
|
- 'nst OSes:TOSes) : TTarget;'#010+
|
|
|
- 'begin'#010+
|
|
|
- ' Result:=Add as TTarget;'#010+
|
|
|
- ' Result.Name:=AUnitName;'#010+
|
|
|
- ' Result.TargetType:=TTUnit;'#010+
|
|
|
- ' Result.CPUs:=CPUs;'#010+
|
|
|
- ' Result.OSes',':=OSes;'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
- #010+
|
|
|
+ 'nst O','Ses:TOSes) : TTarget;'#013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' Result:=Add as TTarget;'#013#010+
|
|
|
+ ' Result.Name:=AUnitName;'#013#010+
|
|
|
+ ' Result.TargetType:=TTUnit;'#013#010+
|
|
|
+ ' Result.CPUs:=CPUs;'#013#010+
|
|
|
+ ' Result.OSes:=OSes;'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ #013#010+
|
|
|
'Function TTargets.AddImplicitUnit(Const AUnitName : String;InstallUnit'+
|
|
|
- ':boolean=true) : TTarget;'#010+
|
|
|
- 'begin'#010+
|
|
|
- ' Result:=AddImplicitUnit(AUnitName,AllCPUs,AllOSes,InstallUnit);'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
- #010+
|
|
|
- 'Function TTargets.AddImplicitUnit(Const AUnitName ',': String;const OSe'+
|
|
|
- 's:TOSes;InstallUnit:boolean=true) : TTarget;'#010+
|
|
|
- 'begin'#010+
|
|
|
- ' Result:=AddImplicitUnit(AUnitName,AllCPUs,OSes,InstallUnit);'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
- #010+
|
|
|
+ ':b','oolean=true) : TTarget;'#013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' Result:=AddImplicitUnit(AUnitName,AllCPUs,AllOSes,InstallUnit);'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ #013#010+
|
|
|
+ 'Function TTargets.AddImplicitUnit(Const AUnitName : String;const OSes:'+
|
|
|
+ 'TOSes;InstallUnit:boolean=true) : TTarget;'#013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' Result:=','AddImplicitUnit(AUnitName,AllCPUs,OSes,InstallUnit);'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ #013#010+
|
|
|
'Function TTargets.AddImplicitUnit(Const AUnitName : String;const CPUs:'+
|
|
|
- 'TCPUs;InstallUnit:boolean=true)',' : TTarget;'#010+
|
|
|
- 'begin'#010+
|
|
|
- ' Result:=AddImplicitUnit(AUnitName,CPUs,AllOSes,InstallUnit);'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
- #010+
|
|
|
+ 'TCPUs;InstallUnit:boolean=true) : TTarget;'#013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' Result:=AddImplicitUnit(AUnitName,CPUs,AllOSes,Instal','lUnit);'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ #013#010+
|
|
|
'Function TTargets.AddImplicitUnit(Const AUnitName : String;const CPUs:'+
|
|
|
- 'TCPUs;const OSes:TOSes;InstallUnit:boolean=true) : TTarget;'#010+
|
|
|
- 'begin'#010+
|
|
|
- ' Result:=Add as',' TTarget;'#010+
|
|
|
- ' Result.Name:=AUnitName;'#010+
|
|
|
- ' Result.CPUs:=CPUs;'#010+
|
|
|
- ' Result.OSes:=OSes;'#010+
|
|
|
- ' if InstallUnit then'#010+
|
|
|
- ' Result.TargetType:=TTImplicitUnit'#010+
|
|
|
- ' else'#010+
|
|
|
- ' Result.TargetType:=TTCleanOnlyUnit;'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
- #010+
|
|
|
- 'Function TTargets.AddProgram(Const AProgramName ',': String) : TTarget;'+
|
|
|
- #010+
|
|
|
- 'begin'#010+
|
|
|
- ' Result:=AddProgram(AProgramName,AllCPUs,AllOSes);'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
- #010+
|
|
|
+ 'TCPUs;const OSes:TOSes;InstallUnit:boolean=true) : TTarget;'#013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' Result:=Add as TTarget;'#013#010+
|
|
|
+ ' Result.Name:=AUnitName;'#013#010+
|
|
|
+ ' Result.CPUs:=CPUs;'#013#010+
|
|
|
+ ' Resul','t.OSes:=OSes;'#013#010+
|
|
|
+ ' if InstallUnit then'#013#010+
|
|
|
+ ' Result.TargetType:=TTImplicitUnit'#013#010+
|
|
|
+ ' else'#013#010+
|
|
|
+ ' Result.TargetType:=TTCleanOnlyUnit;'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ #013#010+
|
|
|
+ 'Function TTargets.AddProgram(Const AProgramName : String) : TTarget;'#013+
|
|
|
+ #010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' Result:=AddProgram(AProgr','amName,AllCPUs,AllOSes);'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ #013#010+
|
|
|
'Function TTargets.AddProgram(Const AProgramName : String;const OSes:TO'+
|
|
|
- 'Ses) : TTarget;'#010+
|
|
|
- 'begin'#010+
|
|
|
- ' Result:=AddProgram(AProgramName,AllCPUs,OSes);'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
- #010+
|
|
|
- '{$ifde','f cpu_only_overloads}'#010+
|
|
|
+ 'Ses) : TTarget;'#013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' Result:=AddProgram(AProgramName,AllCPUs,OSes);'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ #013#010+
|
|
|
+ '{$ifdef cpu_only_overloads}'#013#010+
|
|
|
+ 'Function TTargets.Add','Program(Const AProgramName : String;const CPUs:'+
|
|
|
+ 'TCPUs) : TTarget;'#013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' Result:=AddProgram(AProgramName,CPUs,AllOSes);'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ '{$endif cpu_only_overloads}'#013#010+
|
|
|
+ #013#010+
|
|
|
+ #013#010+
|
|
|
'Function TTargets.AddProgram(Const AProgramName : String;const CPUs:TC'+
|
|
|
- 'PUs) : TTarget;'#010+
|
|
|
- 'begin'#010+
|
|
|
- ' Result:=AddProgram(AProgramName,CPUs,AllOSes);'#010+
|
|
|
- 'end;'#010+
|
|
|
- '{$endif cpu_only_overloads}'#010+
|
|
|
- #010+
|
|
|
- #010+
|
|
|
- 'Function TTargets.AddProgram(Const AProgra','mName : String;const CPUs:'+
|
|
|
- 'TCPUs;const OSes:TOSes) : TTarget;'#010+
|
|
|
- 'begin'#010+
|
|
|
- ' Result:=Add as TTarget;'#010+
|
|
|
- ' Result.Name:=AProgramName;'#010+
|
|
|
- ' Result.CPUs:=CPUs;'#010+
|
|
|
- ' Result.OSes:=OSes;'#010+
|
|
|
- ' Result.TargetType:=ttProgram;'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
- #010+
|
|
|
- 'Function TTargets.AddExampleUnit(Cons','t AUnitName : String) : TTarget'+
|
|
|
- ';'#010+
|
|
|
- 'begin'#010+
|
|
|
- ' Result:=AddExampleUnit(AUnitName,AllCPUs,AllOSes);'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
- #010+
|
|
|
+ 'PUs;cons','t OSes:TOSes) : TTarget;'#013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' Result:=Add as TTarget;'#013#010+
|
|
|
+ ' Result.Name:=AProgramName;'#013#010+
|
|
|
+ ' Result.CPUs:=CPUs;'#013#010+
|
|
|
+ ' Result.OSes:=OSes;'#013#010+
|
|
|
+ ' Result.TargetType:=ttProgram;'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ #013#010+
|
|
|
+ 'Function TTargets.AddExampleUnit(Const AUnitName : String) : TT','arget'+
|
|
|
+ ';'#013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' Result:=AddExampleUnit(AUnitName,AllCPUs,AllOSes);'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ #013#010+
|
|
|
'Function TTargets.AddExampleUnit(Const AUnitName : String;const OSes:T'+
|
|
|
- 'OSes) : TTarget;'#010+
|
|
|
- 'begin'#010+
|
|
|
- ' Result:=AddExampleUnit(AUnitName,AllCPUs,OSes)',';'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
- #010+
|
|
|
- '{$ifdef cpu_only_overloads}'#010+
|
|
|
+ 'OSes) : TTarget;'#013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' Result:=AddExampleUnit(AUnitName,AllCPUs,OSes);'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ #013#010+
|
|
|
+ '{$ifd','ef cpu_only_overloads}'#013#010+
|
|
|
'Function TTargets.AddExampleUnit(Const AUnitName : String;const CPUs:T'+
|
|
|
- 'CPUs) : TTarget;'#010+
|
|
|
- 'begin'#010+
|
|
|
- ' Result:=AddExampleUnit(AUnitName,CPUs,AllOSes);'#010+
|
|
|
- 'end;'#010+
|
|
|
- '{$endif cpu_only_overloads}'#010+
|
|
|
- #010+
|
|
|
- #010+
|
|
|
- 'Function TTargets.AddExam','pleUnit(Const AUnitName : String;const CPUs'+
|
|
|
- ':TCPUs;const OSes:TOSes) : TTarget;'#010+
|
|
|
- 'begin'#010+
|
|
|
- ' Result:=Add as TTarget;'#010+
|
|
|
- ' Result.Name:=AUnitName;'#010+
|
|
|
- ' Result.CPUs:=CPUs;'#010+
|
|
|
- ' Result.OSes:=OSes;'#010+
|
|
|
- ' Result.TargetType:=ttExampleUnit;'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
- #010+
|
|
|
- 'Function TTargets.','AddExampleProgram(Const AProgramName : String) : T'+
|
|
|
- 'Target;'#010+
|
|
|
- 'begin'#010+
|
|
|
- ' Result:=AddExampleProgram(AProgramName,AllCPUs,AllOSes);'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
- #010+
|
|
|
+ 'CPUs) : TTarget;'#013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' Result:=AddExampleUnit(AUnitName,CPUs,AllOSes);'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ '{$endif cpu_only_overloads}'#013#010+
|
|
|
+ #013#010+
|
|
|
+ #013#010+
|
|
|
+ 'Function TTargets.AddExampleUni','t(Const AUnitName : String;const CPUs'+
|
|
|
+ ':TCPUs;const OSes:TOSes) : TTarget;'#013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' Result:=Add as TTarget;'#013#010+
|
|
|
+ ' Result.Name:=AUnitName;'#013#010+
|
|
|
+ ' Result.CPUs:=CPUs;'#013#010+
|
|
|
+ ' Result.OSes:=OSes;'#013#010+
|
|
|
+ ' Result.TargetType:=ttExampleUnit;'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ #013#010+
|
|
|
+ 'Function TTarg','ets.AddExampleProgram(Const AProgramName : String) : T'+
|
|
|
+ 'Target;'#013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' Result:=AddExampleProgram(AProgramName,AllCPUs,AllOSes);'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ #013#010+
|
|
|
'Function TTargets.AddExampleProgram(Const AProgramName : String;const '+
|
|
|
- 'OSes:TOSes) : TTarget;'#010+
|
|
|
- 'begin'#010+
|
|
|
- ' Result:=A','ddExampleProgram(AProgramName,AllCPUs,OSes);'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
- #010+
|
|
|
- '{$ifdef cpu_only_overloads}'#010+
|
|
|
+ 'OSes:TOSes) : TTarget;'#013#010+
|
|
|
+ 'begin'#013,#010+
|
|
|
+ ' Result:=AddExampleProgram(AProgramName,AllCPUs,OSes);'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ #013#010+
|
|
|
+ '{$ifdef cpu_only_overloads}'#013#010+
|
|
|
'Function TTargets.AddExampleProgram(Const AProgramName : String;const '+
|
|
|
- 'CPUs:TCPUs) : TTarget;'#010+
|
|
|
- 'begin'#010+
|
|
|
- ' Result:=AddExampleProgram(AProgramName,CPUs,AllOSes);'#010+
|
|
|
- 'end;'#010,
|
|
|
- '{$endif cpu_only_overloads}'#010+
|
|
|
- #010+
|
|
|
- #010+
|
|
|
+ 'CPUs:TCPUs) : TTarget;'#013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' Result:=AddExampleProgram(AProgramName,C','PUs,AllOSes);'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ '{$endif cpu_only_overloads}'#013#010+
|
|
|
+ #013#010+
|
|
|
+ #013#010+
|
|
|
'Function TTargets.AddExampleProgram(Const AProgramName : String;const '+
|
|
|
- 'CPUs:TCPUs;const OSes:TOSes) : TTarget;'#010+
|
|
|
- 'begin'#010+
|
|
|
- ' Result:=Add as TTarget;'#010+
|
|
|
- ' Result.Name:=AProgramName;'#010+
|
|
|
- ' Result.CPUs:=CPUs;'#010+
|
|
|
- ' Result.OSes:=OSe','s;'#010+
|
|
|
- ' Result.TargetType:=ttExampleProgram;'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
- #010+
|
|
|
+ 'CPUs:TCPUs;const OSes:TOSes) : TTarget;'#013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' Result:=Add as TTarget;'#013#010+
|
|
|
+ ' Result.Name:=AProgramName;'#013#010+
|
|
|
+ ' Result.CP','Us:=CPUs;'#013#010+
|
|
|
+ ' Result.OSes:=OSes;'#013#010+
|
|
|
+ ' Result.TargetType:=ttExampleProgram;'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ #013#010+
|
|
|
'{*********************************************************************'+
|
|
|
- '*******'#010+
|
|
|
- ' TSources'#010+
|
|
|
- '**********************************************************************'+
|
|
|
- '**','****}'#010+
|
|
|
- #010+
|
|
|
- 'function TSources.GetSourceItem(Index : Integer): TSource;'#010+
|
|
|
- 'begin'#010+
|
|
|
- ' Result:=TSource(Items[Index]);'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
- #010+
|
|
|
+ '*******'#013#010+
|
|
|
+ ' TSources'#013#010+
|
|
|
+ '************************************','********************************'+
|
|
|
+ '********}'#013#010+
|
|
|
+ #013#010+
|
|
|
+ 'function TSources.GetSourceItem(Index : Integer): TSource;'#013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' Result:=TSource(Items[Index]);'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ #013#010+
|
|
|
'procedure TSources.SetSourceItem(Index : Integer; const AValue: TSourc'+
|
|
|
- 'e);'#010+
|
|
|
- 'begin'#010+
|
|
|
- ' Items[Index]:=AValue;'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
- #010+
|
|
|
- 'function TSources','.AddDoc (const AFiles : String) : TSource;'#010+
|
|
|
- 'begin'#010+
|
|
|
- ' Result:=Add as TSource;'#010+
|
|
|
- ' Result.Name:=AFiles;'#010+
|
|
|
- ' Result.FSourceType:=stDoc;'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
- #010+
|
|
|
- 'function TSources.AddDoc(const AFiles: String; AInstallSourcePath: Str'+
|
|
|
- 'ing): TSource;'#010+
|
|
|
- 'begin'#010+
|
|
|
- ' Result:=Add a','s TSource;'#010+
|
|
|
- ' Result.Name:=AFiles;'#010+
|
|
|
- ' Result.FInstallSourcePath:=AInstallSourcePath;'#010+
|
|
|
- ' Result.FSourceType:=stDoc;'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
- #010+
|
|
|
- 'function TSources.AddSrc(const AFiles : String) : TSource;'#010+
|
|
|
- 'begin'#010+
|
|
|
- ' Result:=Add as TSource;'#010+
|
|
|
- ' Result.Name:=AFiles;'#010+
|
|
|
- ' Resul','t.FSourceType:=stSrc;'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
- #010+
|
|
|
- 'function TSources.AddExample(const AFiles : String) : TSource;'#010+
|
|
|
- 'begin'#010+
|
|
|
- ' Result:=Add as TSource;'#010+
|
|
|
- ' Result.Name:=AFiles;'#010+
|
|
|
- ' Result.FSourceType:=stExample;'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
- 'function TSources.AddExample(const AFiles: String; AIn','stallSourcePat'+
|
|
|
- 'h: String): TSource;'#010+
|
|
|
- 'begin'#010+
|
|
|
- ' Result:=Add as TSource;'#010+
|
|
|
- ' Result.Name:=AFiles;'#010+
|
|
|
- ' Result.FInstallSourcePath:=AInstallSourcePath;'#010+
|
|
|
- ' Result.FSourceType:=stExample;'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
- #010+
|
|
|
- 'function TSources.AddTest(const AFiles : String) : TSource;'#010+
|
|
|
- 'b','egin'#010+
|
|
|
- ' Result:=Add as TSource;'#010+
|
|
|
- ' Result.Name:=AFiles;'#010+
|
|
|
- ' Result.FSourceType:=stTest;'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
- #010+
|
|
|
- 'procedure TSources.AddDocFiles(const AFileMask: string; Recursive: boo'+
|
|
|
- 'lean; AInstallSourcePath : String = '#039#039');'#010+
|
|
|
- 'var'#010+
|
|
|
- ' List : TStrings;'#010+
|
|
|
- ' i: integer;'#010+
|
|
|
- 'b','egin'#010+
|
|
|
- ' List := TStringList.Create;'#010+
|
|
|
- ' SearchFiles(AFileMask, Recursive, List);'#010+
|
|
|
- ' for i:= 0 to Pred(List.Count) do'#010+
|
|
|
- ' AddDoc(List[i], AInstallSourcePath);'#010+
|
|
|
- ' List.Free;'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
- #010+
|
|
|
- 'procedure TSources.AddSrcFiles(const AFileMask: string; Recursive:',' b'+
|
|
|
- 'oolean);'#010+
|
|
|
- 'var'#010+
|
|
|
- ' List : TStrings;'#010+
|
|
|
- ' i: integer;'#010+
|
|
|
- 'begin'#010+
|
|
|
- ' List := TStringList.Create;'#010+
|
|
|
- ' SearchFiles(AFileMask, Recursive, List);'#010+
|
|
|
- ' for i:= 0 to Pred(List.Count) do'#010+
|
|
|
- ' AddSrc(List[i]);'#010+
|
|
|
- ' List.Free;'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
- #010+
|
|
|
- 'procedure TSources.AddExampleFiles(co','nst AFileMask: string; Recursiv'+
|
|
|
- 'e: boolean; AInstallSourcePath : String = '#039#039');'#010+
|
|
|
- 'var'#010+
|
|
|
- ' List : TStrings;'#010+
|
|
|
- ' i: integer;'#010+
|
|
|
- 'begin'#010+
|
|
|
- ' List := TStringList.Create;'#010+
|
|
|
- ' SearchFiles(AFileMask, Recursive, List);'#010+
|
|
|
- ' for i:= 0 to Pred(List.Count) do'#010+
|
|
|
- ' AddExam','ple(List[i], AInstallSourcePath);'#010+
|
|
|
- ' List.Free;'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
- #010+
|
|
|
- 'procedure TSources.AddTestFiles(const AFileMask: string; Recursive: bo'+
|
|
|
- 'olean);'#010+
|
|
|
- 'var'#010+
|
|
|
- ' List : TStrings;'#010+
|
|
|
- ' i: integer;'#010+
|
|
|
- 'begin'#010+
|
|
|
- ' List := TStringList.Create;'#010+
|
|
|
- ' SearchFiles(AFileMask, Recursive,',' List);'#010+
|
|
|
- ' for i:= 0 to Pred(List.Count) do'#010+
|
|
|
- ' AddTest(List[i]);'#010+
|
|
|
- ' List.Free;'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
- #010+
|
|
|
- '{*********************************************************************'+
|
|
|
- '*******'#010+
|
|
|
- ' TPackage'#010+
|
|
|
- '***************************************','*****************************'+
|
|
|
- '********}'#010+
|
|
|
- #010+
|
|
|
- 'constructor TPackage.Create(ACollection: TCollection);'#010+
|
|
|
- 'begin'#010+
|
|
|
- ' inherited Create(ACollection);'#010+
|
|
|
- ' FVersion:=TFPVersion.Create;'#010+
|
|
|
- ' FTargets:=TTargets.Create(TTarget);'#010+
|
|
|
- ' FSources:=TSources.Create(TSource);',#010+
|
|
|
- ' FDependencies:=TDependencies.Create(TDependency);'#010+
|
|
|
- ' FInstallFiles:=TConditionalDestStrings.Create(TConditionalDestString'+
|
|
|
- ');'#010+
|
|
|
- ' FCleanFiles:=TConditionalStrings.Create(TConditionalString);'#010+
|
|
|
- ' FUnitPath:=TConditionalStrings.Create(TConditiona','lString);'#010+
|
|
|
- ' FObjectPath:=TConditionalStrings.Create(TConditionalString);'#010+
|
|
|
- ' FIncludePath:=TConditionalStrings.Create(TConditionalString);'#010+
|
|
|
- ' FSourcePath:=TConditionalStrings.Create(TConditionalString);'#010+
|
|
|
- ' FExamplePath:=TConditionalStrings.Crea','te(TConditionalString);'#010+
|
|
|
- ' FTestPath:=TConditionalStrings.Create(TConditionalString);'#010+
|
|
|
- ' FCommands:=TCommands.Create(TCommand);'#010+
|
|
|
+ 'e);'#013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' ','Items[Index]:=AValue;'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ #013#010+
|
|
|
+ 'function TSources.AddDoc (const AFiles : String) : TSource;'#013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' Result:=Add as TSource;'#013#010+
|
|
|
+ ' Result.Name:=AFiles;'#013#010+
|
|
|
+ ' Result.FSourceType:=stDoc;'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ #013#010+
|
|
|
+ 'function TSources.AddDoc(const AFiles: String; A','InstallSourcePath: S'+
|
|
|
+ 'tring): TSource;'#013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' Result:=Add as TSource;'#013#010+
|
|
|
+ ' Result.Name:=AFiles;'#013#010+
|
|
|
+ ' Result.FInstallSourcePath:=AInstallSourcePath;'#013#010+
|
|
|
+ ' Result.FSourceType:=stDoc;'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ #013#010+
|
|
|
+ 'function TSources.AddSrc(const AFiles : String) : TSou','rce;'#013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' Result:=Add as TSource;'#013#010+
|
|
|
+ ' Result.Name:=AFiles;'#013#010+
|
|
|
+ ' Result.FSourceType:=stSrc;'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ #013#010+
|
|
|
+ 'function TSources.AddExample(const AFiles : String) : TSource;'#013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' Result:=Add as TSource;'#013#010+
|
|
|
+ ' Result.Name:=AFiles;'#013#010+
|
|
|
+ ' Result.FSour','ceType:=stExample;'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ 'function TSources.AddExample(const AFiles: String; AInstallSourcePath:'+
|
|
|
+ ' String): TSource;'#013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' Result:=Add as TSource;'#013#010+
|
|
|
+ ' Result.Name:=AFiles;'#013#010+
|
|
|
+ ' Result.FInstallSourcePath:=AInstallSourcePath;'#013#010+
|
|
|
+ ' Result.FSour','ceType:=stExample;'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ #013#010+
|
|
|
+ 'function TSources.AddTest(const AFiles : String) : TSource;'#013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' Result:=Add as TSource;'#013#010+
|
|
|
+ ' Result.Name:=AFiles;'#013#010+
|
|
|
+ ' Result.FSourceType:=stTest;'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ #013#010+
|
|
|
+ 'procedure TSources.AddDocFiles(const AFileMask: st','ring; Recursive: b'+
|
|
|
+ 'oolean; AInstallSourcePath : String = '#039#039');'#013#010+
|
|
|
+ 'var'#013#010+
|
|
|
+ ' List : TStrings;'#013#010+
|
|
|
+ ' i: integer;'#013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' List := TStringList.Create;'#013#010+
|
|
|
+ ' SearchFiles(AFileMask, Recursive, List);'#013#010+
|
|
|
+ ' for i:= 0 to Pred(List.Count) do'#013#010+
|
|
|
+ ' AddDoc(List[i], ','AInstallSourcePath);'#013#010+
|
|
|
+ ' List.Free;'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ #013#010+
|
|
|
+ 'procedure TSources.AddSrcFiles(const AFileMask: string; Recursive: boo'+
|
|
|
+ 'lean);'#013#010+
|
|
|
+ 'var'#013#010+
|
|
|
+ ' List : TStrings;'#013#010+
|
|
|
+ ' i: integer;'#013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' List := TStringList.Create;'#013#010+
|
|
|
+ ' SearchFiles(AFileMask, Recursive, Li','st);'#013#010+
|
|
|
+ ' for i:= 0 to Pred(List.Count) do'#013#010+
|
|
|
+ ' AddSrc(List[i]);'#013#010+
|
|
|
+ ' List.Free;'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ #013#010+
|
|
|
+ 'procedure TSources.AddExampleFiles(const AFileMask: string; Recursive:'+
|
|
|
+ ' boolean; AInstallSourcePath : String = '#039#039');'#013#010+
|
|
|
+ 'var'#013#010+
|
|
|
+ ' List : TStrings;'#013#010+
|
|
|
+ ' i: intege','r;'#013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' List := TStringList.Create;'#013#010+
|
|
|
+ ' SearchFiles(AFileMask, Recursive, List);'#013#010+
|
|
|
+ ' for i:= 0 to Pred(List.Count) do'#013#010+
|
|
|
+ ' AddExample(List[i], AInstallSourcePath);'#013#010+
|
|
|
+ ' List.Free;'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ #013#010+
|
|
|
+ 'procedure TSources.AddTestFiles(const AFileMask:',' string; Recursive: '+
|
|
|
+ 'boolean);'#013#010+
|
|
|
+ 'var'#013#010+
|
|
|
+ ' List : TStrings;'#013#010+
|
|
|
+ ' i: integer;'#013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' List := TStringList.Create;'#013#010+
|
|
|
+ ' SearchFiles(AFileMask, Recursive, List);'#013#010+
|
|
|
+ ' for i:= 0 to Pred(List.Count) do'#013#010+
|
|
|
+ ' AddTest(List[i]);'#013#010+
|
|
|
+ ' List.Free;'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ #013#010+
|
|
|
+ '{***','****************************************************************'+
|
|
|
+ '*********'#013#010+
|
|
|
+ ' TPackage'#013#010+
|
|
|
+ '**********************************************************************'+
|
|
|
+ '******}'#013#010+
|
|
|
+ #013#010+
|
|
|
+ 'constructor TPackage.Create(ACollection: TCol','lection);'#013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' inherited Create(ACollection);'#013#010+
|
|
|
+ ' FVersion:=TFPVersion.Create;'#013#010+
|
|
|
+ ' FTargets:=TTargets.Create(TTarget);'#013#010+
|
|
|
+ ' FSources:=TSources.Create(TSource);'#013#010+
|
|
|
+ ' FDependencies:=TDependencies.Create(TDependency);'#013#010+
|
|
|
+ ' FInstallFiles:=TConditi','onalDestStrings.Create(TConditionalDestStri'+
|
|
|
+ 'ng);'#013#010+
|
|
|
+ ' FCleanFiles:=TConditionalStrings.Create(TConditionalString);'#013#010+
|
|
|
+ ' FUnitPath:=TConditionalStrings.Create(TConditionalString);'#013#010+
|
|
|
+ ' FObjectPath:=TConditionalStrings.Create(TConditionalString);'#013#010+
|
|
|
+ ' ',' FIncludePath:=TConditionalStrings.Create(TConditionalString);'#013#010+
|
|
|
+ ' FSourcePath:=TConditionalStrings.Create(TConditionalString);'#013#010+
|
|
|
+ ' FExamplePath:=TConditionalStrings.Create(TConditionalString);'#013#010+
|
|
|
+ ' FTestPath:=TConditionalStrings.Create(TCondit','ionalString);'#013#010+
|
|
|
+ ' FCommands:=TCommands.Create(TCommand);'#013#010+
|
|
|
' FUnitsOutputDir:='#039'units'#039'+PathDelim+'#039'$(target)'#039'+PathD'+
|
|
|
- 'elim;'#010+
|
|
|
- ' FPackageVariants:=TFPList.Create;'#010+
|
|
|
- ' FCPUs:=AllCPUs;'#010,
|
|
|
- ' FOSes:=AllOSes;'#010+
|
|
|
- ' FInstalledChecksum:=$ffffffff;'#010+
|
|
|
- ' FFlags := TStringList.Create;'#010+
|
|
|
- ' // Implicit dependency on RTL'#010+
|
|
|
- ' FDependencies.Add('#039'rtl'#039');'#010+
|
|
|
- ' FSupportBuildModes:=[bmBuildUnit, bmOneByOne];'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
- #010+
|
|
|
- 'destructor TPackage.destroy;'#010+
|
|
|
- 'var'#010+
|
|
|
- ' i: int','eger;'#010+
|
|
|
- 'begin'#010+
|
|
|
- ' FreeAndNil(FDictionary);'#010+
|
|
|
- ' FreeAndNil(FDependencies);'#010+
|
|
|
- ' FreeAndNil(FInstallFiles);'#010+
|
|
|
- ' FreeAndNil(FCleanFiles);'#010+
|
|
|
- ' FreeAndNil(FIncludePath);'#010+
|
|
|
- ' FreeAndNil(FSourcePath);'#010+
|
|
|
- ' FreeAndNil(FExamplePath);'#010+
|
|
|
- ' FreeAndNil(FTestPath);'#010+
|
|
|
- ' FreeAn','dNil(FCommands);'#010+
|
|
|
- ' FreeAndNil(FObjectPath);'#010+
|
|
|
- ' FreeAndNil(FUnitPath);'#010+
|
|
|
- ' FreeAndNil(FSources);'#010+
|
|
|
- ' FreeAndNil(FTargets);'#010+
|
|
|
- ' FreeAndNil(FVersion);'#010+
|
|
|
- ' FreeAndNil(FOptions);'#010+
|
|
|
- ' FreeAndNil(FFlags);'#010+
|
|
|
- ' FreeAndNil(FPackageVariants);'#010+
|
|
|
- ' inherited destroy;'#010,
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
- 'function TPackage.HaveOptions: Boolean;'#010+
|
|
|
- 'begin'#010+
|
|
|
- ' Result:=(FOptions<>Nil);'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
- #010+
|
|
|
- 'procedure TPackage.SetName(const AValue: String);'#010+
|
|
|
- 'begin'#010+
|
|
|
- ' inherited SetName(AValue);'#010+
|
|
|
- ' // RTL should not have any dependencies'#010+
|
|
|
- ' if AValue='#039'rtl'#039' then'#010+
|
|
|
- ' ','FDependencies.Clear;'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
- #010+
|
|
|
- 'Function TPackage.GetUnitsOutputDir(ACPU:TCPU; AOS : TOS):String;'#010+
|
|
|
- 'begin'#010+
|
|
|
+ 'elim;'#013#010+
|
|
|
+ ' FPackageVariants:=TFPList.Create;'#013#010+
|
|
|
+ ' FCPUs:=AllCPUs;'#013#010+
|
|
|
+ ' FOSes:=AllOSes;'#013#010+
|
|
|
+ ' FInstalledChecksum:=$ffffffff;'#013#010+
|
|
|
+ ' FFlags := T','StringList.Create;'#013#010+
|
|
|
+ ' // Implicit dependency on RTL'#013#010+
|
|
|
+ ' FDependencies.Add('#039'rtl'#039');'#013#010+
|
|
|
+ ' FSupportBuildModes:=[bmBuildUnit, bmOneByOne];'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ #013#010+
|
|
|
+ 'destructor TPackage.destroy;'#013#010+
|
|
|
+ 'var'#013#010+
|
|
|
+ ' i: integer;'#013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' FreeAndNil(FDictionary);'#013#010+
|
|
|
+ ' FreeAndNil(','FDependencies);'#013#010+
|
|
|
+ ' FreeAndNil(FInstallFiles);'#013#010+
|
|
|
+ ' FreeAndNil(FCleanFiles);'#013#010+
|
|
|
+ ' FreeAndNil(FIncludePath);'#013#010+
|
|
|
+ ' FreeAndNil(FSourcePath);'#013#010+
|
|
|
+ ' FreeAndNil(FExamplePath);'#013#010+
|
|
|
+ ' FreeAndNil(FTestPath);'#013#010+
|
|
|
+ ' FreeAndNil(FCommands);'#013#010+
|
|
|
+ ' FreeAndNil(FObjectPath);'#013,#010+
|
|
|
+ ' FreeAndNil(FUnitPath);'#013#010+
|
|
|
+ ' FreeAndNil(FSources);'#013#010+
|
|
|
+ ' FreeAndNil(FTargets);'#013#010+
|
|
|
+ ' FreeAndNil(FVersion);'#013#010+
|
|
|
+ ' FreeAndNil(FOptions);'#013#010+
|
|
|
+ ' FreeAndNil(FFlags);'#013#010+
|
|
|
+ ' FreeAndNil(FPackageVariants);'#013#010+
|
|
|
+ ' inherited destroy;'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ 'function TPackage.HaveOptio','ns: Boolean;'#013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' Result:=(FOptions<>Nil);'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ #013#010+
|
|
|
+ 'procedure TPackage.SetName(const AValue: String);'#013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' inherited SetName(AValue);'#013#010+
|
|
|
+ ' // RTL should not have any dependencies'#013#010+
|
|
|
+ ' if AValue='#039'rtl'#039' then'#013#010+
|
|
|
+ ' FDependencies.Clear;'#013#010,
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ #013#010+
|
|
|
+ 'Function TPackage.GetUnitsOutputDir(ACPU:TCPU; AOS : TOS):String;'#013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
' result:=FixPath(Dictionary.Substitute(FUnitsOutputDir,['#039'CPU'#039','+
|
|
|
'CPUToString(ACPU),'#039'OS'#039',OSToString(AOS),'#039'target'#039',MakeTa'+
|
|
|
- 'rgetString(ACPU,AOS)]),',' True);'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
+ 'rgetString(ACPU,AOS)]), False);'#013#010+
|
|
|
+ 'end;'#013#010,
|
|
|
+ #013#010+
|
|
|
'function TPackage.GetUnitConfigOutputDir(ACPU: TCPU; AOS: TOS): String'+
|
|
|
- ';'#010+
|
|
|
- 'begin'#010+
|
|
|
+ ';'#013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
' result:=FixPath(Dictionary.Substitute('#039'units'#039'+PathDelim+'#039+
|
|
|
'$(target)'#039'+PathDelim,['#039'CPU'#039',CPUToString(ACPU),'#039'OS'#039','+
|
|
|
- 'OSToString(AOS),'#039'target'#039',MakeTargetStr','ing(ACPU,AOS)]), True)'+
|
|
|
- ';'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
+ 'OSToString(AOS),'#039'target'#039',MakeTargetString(ACPU,A','OS)]), False'+
|
|
|
+ ');'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
'procedure TPackage.InheritPackageVariantsFromDependency(ADependencyPac'+
|
|
|
- 'kage: TPackage);'#010+
|
|
|
- 'var'#010+
|
|
|
- ' i: integer;'#010+
|
|
|
- ' APackageVariants: TPackageVariants;'#010+
|
|
|
- 'begin'#010+
|
|
|
- ' for i := 0 to ADependencyPackage.FPackageVariants.Count-1 d','o'#010+
|
|
|
- ' begin'#010+
|
|
|
+ 'kage: TPackage);'#013#010+
|
|
|
+ 'var'#013#010+
|
|
|
+ ' i: integer;'#013#010+
|
|
|
+ ' APackageVariants: TPackageVariants;'#013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' for i := 0 to ADependencyPackage.FPackageVariants.Count-1 do',#013#010+
|
|
|
+ ' begin'#013#010+
|
|
|
' APackageVariants := TPackageVariants(ADependencyPackage.FPackage'+
|
|
|
- 'Variants[i]);'#010+
|
|
|
- ' if APackageVariants.IsInheritable then'#010+
|
|
|
- ' begin'#010+
|
|
|
+ 'Variants[i]);'#013#010+
|
|
|
+ ' if APackageVariants.IsInheritable then'#013#010+
|
|
|
+ ' begin'#013#010+
|
|
|
' if not assigned(GetPackageVariantsByName(APackageVariants.Name'+
|
|
|
- ')) then'#010+
|
|
|
- ' ',' begin'#010+
|
|
|
- ' FPackageVariants.Add(APackageVariants);'#010+
|
|
|
- ' end;'#010+
|
|
|
- ' end;'#010+
|
|
|
- ' end;'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
+ ')) then'#013#010+
|
|
|
+ ' ',' begin'#013#010+
|
|
|
+ ' FPackageVariants.Add(APackageVariants);'#013#010+
|
|
|
+ ' end;'#013#010+
|
|
|
+ ' end;'#013#010+
|
|
|
+ ' end;'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
'function TPackage.GetPackageVariantsByName(AName: string): TPackageVar'+
|
|
|
- 'iants;'#010+
|
|
|
- 'var'#010+
|
|
|
- ' i: Integer;'#010+
|
|
|
- 'begin'#010+
|
|
|
- ' result := nil;'#010+
|
|
|
- ' for i := 0 to FPac','kageVariants.Count-1 do'#010+
|
|
|
+ 'iants;'#013#010+
|
|
|
+ 'var'#013#010+
|
|
|
+ ' i: Integer;'#013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' result := nil;'#013#010+
|
|
|
+ ' f','or i := 0 to FPackageVariants.Count-1 do'#013#010+
|
|
|
' if SameText(TPackageVariants(FPackageVariants.Items[i]).Name, ANam'+
|
|
|
- 'e) then'#010+
|
|
|
- ' begin'#010+
|
|
|
- ' result := TPackageVariants(FPackageVariants.Items[i]);'#010+
|
|
|
- ' break;'#010+
|
|
|
- ' end;'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
- 'procedure TPackage.SetUnitsOutputDi','r(AValue: string);'#010+
|
|
|
- 'begin'#010+
|
|
|
- ' if AValue<>'#039#039' then'#010+
|
|
|
- ' FUnitsOutputDir:=IncludeTrailingPathDelimiter(AValue)'#010+
|
|
|
- ' else'#010+
|
|
|
- ' FUnitsOutputDir:='#039#039';'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
- 'function TPackage.GetPackageUnitInstallDir(ACPU: TCPU; AOS: TOS): Stri'+
|
|
|
- 'ng;'#010+
|
|
|
- 'begin'#010+
|
|
|
- ' result:=FixPath(','Dictionary.Substitute(FPackageUnitInstallDir,['#039+
|
|
|
- 'CPU'#039',CPUToString(ACPU),'#039'OS'#039',OSToString(AOS),'#039'target'#039+
|
|
|
- ',MakeTargetString(ACPU,AOS)]), True);'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
- 'procedure TPackage.SetPackageUnitInstallDir(AValue: string);'#010+
|
|
|
- 'begin'#010+
|
|
|
- ' if AValue<>'#039#039' then'#010+
|
|
|
- ' FPack','ageUnitInstallDir:=IncludeTrailingPathDelimiter(AValue)'#010+
|
|
|
- ' else'#010+
|
|
|
- ' FPackageUnitInstallDir:='#039#039';'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
- #010+
|
|
|
- 'Function TPackage.GetBinOutputDir(ACPU:TCPU; AOS : TOS) : String;'#010+
|
|
|
- 'begin'#010+
|
|
|
- ' Result:='#039'bin'#039'+PathDelim+MakeTargetString(ACPU,AOS);'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
- #010+
|
|
|
- 'proce','dure TPackage.GetCleanFiles(List: TStrings; ACPU:TCPU; AOS : TO'+
|
|
|
- 'S);'#010+
|
|
|
- 'Var'#010+
|
|
|
- ' OB,OU : String;'#010+
|
|
|
- ' I : Integer;'#010+
|
|
|
- 'begin'#010+
|
|
|
- ' OB:=IncludeTrailingPathDelimiter(GetBinOutputDir(ACPU,AOS));'#010+
|
|
|
- ' OU:=IncludeTrailingPathDelimiter(GetUnitsOutputDir(ACPU,AOS));'#010+
|
|
|
- ' ','AddConditionalStrings(Self, List,CleanFiles,ACPU,AOS);'#010+
|
|
|
- ' For I:=0 to FTargets.Count-1 do'#010+
|
|
|
- ' FTargets.TargetItems[I].GetCleanFiles(List, OU, OB, ACPU, AOS);'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
- #010+
|
|
|
- 'procedure TPackage.GetInstallFiles(List: TStrings;Types : TTargetTypes'+
|
|
|
- ';ACPU:','TCPU; AOS : TOS);'#010+
|
|
|
- 'Var'#010+
|
|
|
- ' OB,OU : String;'#010+
|
|
|
- ' I : Integer;'#010+
|
|
|
- ' T : TTarget;'#010+
|
|
|
- 'begin'#010+
|
|
|
- ' if Types=[] then'#010+
|
|
|
- ' AddConditionalStrings(Self, List,InstallFiles,ACPU,AOS)'#010+
|
|
|
- ' else'#010+
|
|
|
- ' begin'#010+
|
|
|
- ' OB:=IncludeTrailingPathDelimiter(GetBinOutputDir(Defaults.CPU,','D'+
|
|
|
- 'efaults.OS));'#010+
|
|
|
+ 'e) then'#013#010+
|
|
|
+ ' begin'#013#010+
|
|
|
+ ' result := TPackageVariants(FPackageVariants.Items[i]);'#013#010+
|
|
|
+ ' break;'#013#010+
|
|
|
+ ' end;'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ 'procedure ','TPackage.SetUnitsOutputDir(AValue: string);'#013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' if AValue<>'#039#039' then'#013#010+
|
|
|
+ ' FUnitsOutputDir:=IncludeTrailingPathDelimiter(AValue)'#013#010+
|
|
|
+ ' else'#013#010+
|
|
|
+ ' FUnitsOutputDir:='#039#039';'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ 'function TPackage.GetPackageUnitInstallDir(ACPU: TCPU; AOS: TOS):',' St'+
|
|
|
+ 'ring;'#013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' result:=FixPath(Dictionary.Substitute(FPackageUnitInstallDir,['#039'C'+
|
|
|
+ 'PU'#039',CPUToString(ACPU),'#039'OS'#039',OSToString(AOS),'#039'target'#039+
|
|
|
+ ',MakeTargetString(ACPU,AOS)]), False);'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ 'procedure TPackage.SetPackageUnitInstallDir(AValue: string',');'#013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' if AValue<>'#039#039' then'#013#010+
|
|
|
+ ' FPackageUnitInstallDir:=IncludeTrailingPathDelimiter(AValue)'#013#010+
|
|
|
+ ' else'#013#010+
|
|
|
+ ' FPackageUnitInstallDir:='#039#039';'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ #013#010+
|
|
|
+ 'Function TPackage.GetBinOutputDir(ACPU:TCPU; AOS : TOS) : String;'#013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' Result:='#039'bin'#039'+','PathDelim+MakeTargetString(ACPU,AOS);'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ #013#010+
|
|
|
+ 'procedure TPackage.GetCleanFiles(List: TStrings; ACPU:TCPU; AOS : TOS)'+
|
|
|
+ ';'#013#010+
|
|
|
+ 'Var'#013#010+
|
|
|
+ ' OB,OU : String;'#013#010+
|
|
|
+ ' I : Integer;'#013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' OB:=IncludeTrailingPathDelimiter(GetBinOutputDir(ACPU,AOS));'#013#010+
|
|
|
+ ' OU:=I','ncludeTrailingPathDelimiter(GetUnitsOutputDir(ACPU,AOS));'#013+
|
|
|
+ #010+
|
|
|
+ ' AddConditionalStrings(Self, List,CleanFiles,ACPU,AOS);'#013#010+
|
|
|
+ ' For I:=0 to FTargets.Count-1 do'#013#010+
|
|
|
+ ' FTargets.TargetItems[I].GetCleanFiles(List, OU, OB, ACPU, AOS);'#013+
|
|
|
+ #010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ #013#010+
|
|
|
+ 'procedure',' TPackage.GetInstallFiles(List: TStrings;Types : TTargetTyp'+
|
|
|
+ 'es;ACPU:TCPU; AOS : TOS);'#013#010+
|
|
|
+ 'Var'#013#010+
|
|
|
+ ' OB,OU : String;'#013#010+
|
|
|
+ ' I : Integer;'#013#010+
|
|
|
+ ' T : TTarget;'#013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' if Types=[] then'#013#010+
|
|
|
+ ' AddConditionalStrings(Self, List,InstallFiles,ACPU,AOS)'#013#010+
|
|
|
+ ' else'#013#010+
|
|
|
+ ' ',' begin'#013#010+
|
|
|
+ ' OB:=IncludeTrailingPathDelimiter(GetBinOutputDir(Defaults.CPU,De'+
|
|
|
+ 'faults.OS));'#013#010+
|
|
|
' OU:=IncludeTrailingPathDelimiter(GetUnitsOutputDir(Defaults.CPU,'+
|
|
|
- 'Defaults.OS));'#010+
|
|
|
- ' For I:=0 to FTargets.Count-1 do'#010+
|
|
|
- ' begin'#010+
|
|
|
- ' T:=FTargets.TargetItems[I];'#010+
|
|
|
- ' if (T.TargetType in Types) and Installer','.BuildEngine.Targe'+
|
|
|
- 'tInstallOK(T, ACPU, AOS) then'#010+
|
|
|
- ' T.GetInstallFiles(List, OU, OB, ACPU, AOS);'#010+
|
|
|
- ' end;'#010+
|
|
|
- ' end;'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
- #010+
|
|
|
- 'procedure TPackage.GetInstallSourceFiles(List: TStrings; SourceTypes :'+
|
|
|
- ' TSourceTypes; TargetTypes : TTargetT','ypes);'#010+
|
|
|
- 'Var'#010+
|
|
|
- ' I : Integer;'#010+
|
|
|
- ' S : TSource;'#010+
|
|
|
- ' T : TTarget;'#010+
|
|
|
- 'begin'#010+
|
|
|
- ' For I:=0 to FSources.Count-1 do'#010+
|
|
|
- ' begin'#010+
|
|
|
- ' S:=FSources.SourceItems[I];'#010+
|
|
|
- ' if (S.SourceType in SourceTypes) then'#010+
|
|
|
- ' S.GetInstallFiles(List);'#010+
|
|
|
- ' end;'#010+
|
|
|
- ' For I:=0 to ','FTargets.Count-1 do'#010+
|
|
|
- ' begin'#010+
|
|
|
- ' T:=FTargets.TargetItems[I];'#010+
|
|
|
- ' if (T.TargetType in TargetTypes) then'#010+
|
|
|
- ' T.GetArchiveFiles(List,Defaults.CPU,Defaults.OS);'#010+
|
|
|
- ' end;'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
- #010+
|
|
|
- 'procedure TPackage.GetArchiveFiles(List: TStrings; ACPU:TC','PU; AOS : '+
|
|
|
- 'TOS);'#010+
|
|
|
- 'Var'#010+
|
|
|
- ' I : Integer;'#010+
|
|
|
- 'begin'#010+
|
|
|
- ' // Targets only'#010+
|
|
|
- ' For I:=0 to FTargets.Count-1 do'#010+
|
|
|
- ' FTargets.TargetItems[I].GetArchiveFiles(List,ACPU,AOS);'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
- 'procedure TPackage.GetArchiveSourceFiles(List: TStrings);'#010+
|
|
|
- 'var'#010+
|
|
|
- ' i : integer;'#010+
|
|
|
- 'begi','n'#010+
|
|
|
- ' for i := 0 to Sources.Count-1 do'#010+
|
|
|
- ' List.Add(Sources[i].Name);'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
- 'Function TPackage.GetDescription : string;'#010+
|
|
|
- 'Var'#010+
|
|
|
- ' FN : String;'#010+
|
|
|
- ' L : TStringList;'#010+
|
|
|
- 'begin'#010+
|
|
|
- ' If (FDescription<>'#039#039') then'#010+
|
|
|
- ' Result:=FDescription'#010+
|
|
|
- ' else'#010+
|
|
|
- ' If (FDescripti','onFile<>'#039#039') then'#010+
|
|
|
- ' begin'#010+
|
|
|
- ' // Always relative to binary name.'#010+
|
|
|
- ' FN:=ExtractFilePath(ParamStr(0));'#010+
|
|
|
- ' FN:=FN+FDescriptionFile;'#010+
|
|
|
- ' If FileExists(FN) then'#010+
|
|
|
- ' begin'#010+
|
|
|
- ' L:=TStringList.Create;'#010+
|
|
|
- ' ',' Try'#010+
|
|
|
- ' L.LoadFromFile(FN);'#010+
|
|
|
- ' Result:=L.Text;'#010+
|
|
|
- ' Finally'#010+
|
|
|
- ' L.Free;'#010+
|
|
|
- ' end;'#010+
|
|
|
- ' end;'#010+
|
|
|
- ' end;'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
- 'function TPackage.GetDictionary: TDictionary;'#010+
|
|
|
- 'begin'#010+
|
|
|
- ' if not assigned(FDictionar','y) then'#010+
|
|
|
- ' FDictionary:=PackageDictionaryClass.Create(Nil);'#010+
|
|
|
- ' result := FDictionary;'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
- #010+
|
|
|
- 'Function TPackage.GetVersion : string;'#010+
|
|
|
- 'begin'#010+
|
|
|
- ' result:=FVersion.AsString;'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
- 'procedure TPackage.SetOptions(const AValue: TStrings);'#010+
|
|
|
- 'begin'#010+
|
|
|
- ' If (','AValue=Nil) or (AValue.Count=0) then'#010+
|
|
|
- ' FreeAndNil(Foptions)'#010+
|
|
|
- ' else'#010+
|
|
|
- ' Options.Assign(AValue);'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
- #010+
|
|
|
- 'Procedure TPackage.SetVersion(const V : string);'#010+
|
|
|
- 'begin'#010+
|
|
|
- ' FVersion.AsString:=V;'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
- #010+
|
|
|
- 'Function TPackage.GetFileName : string;'#010+
|
|
|
- 'begin'#010+
|
|
|
- ' If',' (FFileName<>'#039#039') then'#010+
|
|
|
- ' Result:=FFileName'#010+
|
|
|
- ' else'#010+
|
|
|
- ' if not FVersion.Empty then'#010+
|
|
|
- ' Result := Name + '#039'-'#039' + FVersion.AsString'#010+
|
|
|
- ' else'#010+
|
|
|
- ' Result := Name;'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
- 'function TPackage.GetOptions: TStrings;'#010+
|
|
|
- 'begin'#010+
|
|
|
- ' If (FOptions=Nil) then'#010+
|
|
|
- ' ',' FOptions:=TStringList.Create;'#010+
|
|
|
- ' Result:=FOptions;'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
- #010+
|
|
|
- 'Procedure TPackage.GetManifest(Manifest : TStrings);'#010+
|
|
|
- #010+
|
|
|
- ' procedure AddOSes(const AIndent:string;AOSes:TOSes);'#010+
|
|
|
- ' var'#010+
|
|
|
- ' IOS : TOS;'#010+
|
|
|
- ' begin'#010+
|
|
|
- ' if (AOSes=AllOSes) then'#010+
|
|
|
- ' exit;'#010+
|
|
|
- ' ','Manifest.Add(AIndent+'#039'<oses>'#039');'#010+
|
|
|
- ' for IOS:=low(TOSes) to high(TOSes) do'#010+
|
|
|
- ' if IOS in AOSes then'#010+
|
|
|
+ 'Defaults.OS));'#013#010+
|
|
|
+ ' For I:=0 to FTargets.Count-1 do'#013#010+
|
|
|
+ ' begin'#013#010+
|
|
|
+ ' ',' T:=FTargets.TargetItems[I];'#013#010+
|
|
|
+ ' if (T.TargetType in Types) and Installer.BuildEngine.TargetI'+
|
|
|
+ 'nstallOK(T, ACPU, AOS) then'#013#010+
|
|
|
+ ' T.GetInstallFiles(List, OU, OB, ACPU, AOS);'#013#010+
|
|
|
+ ' end;'#013#010+
|
|
|
+ ' end;'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ #013#010+
|
|
|
+ 'procedure TPackage','.GetInstallSourceFiles(List: TStrings; SourceTypes'+
|
|
|
+ ' : TSourceTypes; TargetTypes : TTargetTypes);'#013#010+
|
|
|
+ 'Var'#013#010+
|
|
|
+ ' I : Integer;'#013#010+
|
|
|
+ ' S : TSource;'#013#010+
|
|
|
+ ' T : TTarget;'#013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' For I:=0 to FSources.Count-1 do'#013#010+
|
|
|
+ ' begin'#013#010+
|
|
|
+ ' S:=FSources.SourceItems[I];'#013#010+
|
|
|
+ ' ',' if (S.SourceType in SourceTypes) then'#013#010+
|
|
|
+ ' S.GetInstallFiles(List);'#013#010+
|
|
|
+ ' end;'#013#010+
|
|
|
+ ' For I:=0 to FTargets.Count-1 do'#013#010+
|
|
|
+ ' begin'#013#010+
|
|
|
+ ' T:=FTargets.TargetItems[I];'#013#010+
|
|
|
+ ' if (T.TargetType in TargetTypes) then'#013#010+
|
|
|
+ ' T.GetArchiveFiles(L','ist,Defaults.CPU,Defaults.OS);'#013#010+
|
|
|
+ ' end;'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ #013#010+
|
|
|
+ 'procedure TPackage.GetArchiveFiles(List: TStrings; ACPU:TCPU; AOS : TO'+
|
|
|
+ 'S);'#013#010+
|
|
|
+ 'Var'#013#010+
|
|
|
+ ' I : Integer;'#013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' // Targets only'#013#010+
|
|
|
+ ' For I:=0 to FTargets.Count-1 do'#013#010+
|
|
|
+ ' FTargets.TargetItems[I].Get','ArchiveFiles(List,ACPU,AOS);'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ 'procedure TPackage.GetArchiveSourceFiles(List: TStrings);'#013#010+
|
|
|
+ 'var'#013#010+
|
|
|
+ ' i : integer;'#013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' for i := 0 to Sources.Count-1 do'#013#010+
|
|
|
+ ' List.Add(Sources[i].Name);'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ 'Function TPackage.GetDescription : stri','ng;'#013#010+
|
|
|
+ 'Var'#013#010+
|
|
|
+ ' FN : String;'#013#010+
|
|
|
+ ' L : TStringList;'#013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' If (FDescription<>'#039#039') then'#013#010+
|
|
|
+ ' Result:=FDescription'#013#010+
|
|
|
+ ' else'#013#010+
|
|
|
+ ' If (FDescriptionFile<>'#039#039') then'#013#010+
|
|
|
+ ' begin'#013#010+
|
|
|
+ ' // Always relative to binary name.'#013#010+
|
|
|
+ ' FN:=ExtractFilePath(Pa','ramStr(0));'#013#010+
|
|
|
+ ' FN:=FN+FDescriptionFile;'#013#010+
|
|
|
+ ' If FileExists(FN) then'#013#010+
|
|
|
+ ' begin'#013#010+
|
|
|
+ ' L:=TStringList.Create;'#013#010+
|
|
|
+ ' Try'#013#010+
|
|
|
+ ' L.LoadFromFile(FN);'#013#010+
|
|
|
+ ' Result:=L.Text;'#013#010+
|
|
|
+ ' Finally'#013#010+
|
|
|
+ ' ',' L.Free;'#013#010+
|
|
|
+ ' end;'#013#010+
|
|
|
+ ' end;'#013#010+
|
|
|
+ ' end;'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ 'function TPackage.GetDictionary: TDictionary;'#013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' if not assigned(FDictionary) then'#013#010+
|
|
|
+ ' FDictionary:=PackageDictionaryClass.Create(Nil);'#013#010+
|
|
|
+ ' result := FDictionar','y;'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ #013#010+
|
|
|
+ 'Function TPackage.GetVersion : string;'#013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' result:=FVersion.AsString;'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ 'procedure TPackage.SetOptions(const AValue: TStrings);'#013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' If (AValue=Nil) or (AValue.Count=0) then'#013#010+
|
|
|
+ ' FreeAndNil(Foptions)'#013#010+
|
|
|
+ ' else'#013#010,
|
|
|
+ ' Options.Assign(AValue);'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ #013#010+
|
|
|
+ 'Procedure TPackage.SetVersion(const V : string);'#013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' FVersion.AsString:=V;'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ #013#010+
|
|
|
+ 'Function TPackage.GetFileName : string;'#013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' If (FFileName<>'#039#039') then'#013#010+
|
|
|
+ ' Result:=FFileName'#013#010+
|
|
|
+ ' else'#013#010+
|
|
|
+ ' ',' if not FVersion.Empty then'#013#010+
|
|
|
+ ' Result := Name + '#039'-'#039' + FVersion.AsString'#013#010+
|
|
|
+ ' else'#013#010+
|
|
|
+ ' Result := Name;'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ 'function TPackage.GetOptions: TStrings;'#013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' If (FOptions=Nil) then'#013#010+
|
|
|
+ ' FOptions:=TStringList.Create;'#013#010+
|
|
|
+ ' Result:=FOp','tions;'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ #013#010+
|
|
|
+ 'Procedure TPackage.GetManifest(Manifest : TStrings);'#013#010+
|
|
|
+ #013#010+
|
|
|
+ ' procedure AddOSes(const AIndent:string;AOSes:TOSes);'#013#010+
|
|
|
+ ' var'#013#010+
|
|
|
+ ' IOS : TOS;'#013#010+
|
|
|
+ ' begin'#013#010+
|
|
|
+ ' if (AOSes=AllOSes) then'#013#010+
|
|
|
+ ' exit;'#013#010+
|
|
|
+ ' Manifest.Add(AIndent+'#039'<oses>'#039');'#013,#010+
|
|
|
+ ' for IOS:=low(TOSes) to high(TOSes) do'#013#010+
|
|
|
+ ' if IOS in AOSes then'#013#010+
|
|
|
' Manifest.Add(Format(AIndent+'#039' <os name="%s"/>'#039',[OSToSt'+
|
|
|
- 'ring(IOS)]));'#010+
|
|
|
- ' Manifest.Add(AIndent+'#039'</oses>'#039');'#010+
|
|
|
- ' end;'#010+
|
|
|
- #010+
|
|
|
- ' procedure AddCPU','s(const AIndent:string;ACPUs:TCPUs);'#010+
|
|
|
- ' var'#010+
|
|
|
- ' ICPU : TCPU;'#010+
|
|
|
- ' begin'#010+
|
|
|
- ' if (ACPUs=AllCPUs) then'#010+
|
|
|
- ' exit;'#010+
|
|
|
- ' Manifest.Add(AIndent+'#039'<cpus>'#039');'#010+
|
|
|
- ' for ICPU:=low(TCPUs) to high(TCPUs) do'#010+
|
|
|
- ' if ICPU in ACPUs then'#010+
|
|
|
- ' Manifest.Add(Form','at(AIndent+'#039' <cpu name="%s"/>'#039',[CPU'+
|
|
|
- 'ToString(ICPU)]));'#010+
|
|
|
- ' Manifest.Add(AIndent+'#039'</cpus>'#039');'#010+
|
|
|
- ' end;'#010+
|
|
|
- #010+
|
|
|
+ 'ring(IOS)]));'#013#010+
|
|
|
+ ' Manifest.Add(AIndent+'#039'</oses>'#039');'#013#010+
|
|
|
+ ' end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ ' procedure AddCPUs(const AIndent:string;AC','PUs:TCPUs);'#013#010+
|
|
|
+ ' var'#013#010+
|
|
|
+ ' ICPU : TCPU;'#013#010+
|
|
|
+ ' begin'#013#010+
|
|
|
+ ' if (ACPUs=AllCPUs) then'#013#010+
|
|
|
+ ' exit;'#013#010+
|
|
|
+ ' Manifest.Add(AIndent+'#039'<cpus>'#039');'#013#010+
|
|
|
+ ' for ICPU:=low(TCPUs) to high(TCPUs) do'#013#010+
|
|
|
+ ' if ICPU in ACPUs then'#013#010+
|
|
|
+ ' Manifest.Add(Format(AIndent+'#039' <cp','u name="%s"/>'#039',[CPU'+
|
|
|
+ 'ToString(ICPU)]));'#013#010+
|
|
|
+ ' Manifest.Add(AIndent+'#039'</cpus>'#039');'#013#010+
|
|
|
+ ' end;'#013#010+
|
|
|
+ #013#010+
|
|
|
' function GetXMLVersionString(sMajor, sMinor, sMicro, sBuild: integer'+
|
|
|
- '): string;'#010+
|
|
|
- ' begin'#010+
|
|
|
- ' Result := '#039'<version'#039';'#010+
|
|
|
- ' if sMajor <> -1 then'#010+
|
|
|
- ' ',' Result := Result + '#039' major="'#039' + IntToStr(sMajor) + '#039+
|
|
|
- '"'#039';'#010+
|
|
|
- ' if sMinor <> -1 then'#010+
|
|
|
+ '): string;'#013#010+
|
|
|
+ ' begin'#013#010+
|
|
|
+ ' Result := '#039'<version'#039';'#013#010+
|
|
|
+ ' if sMajor <> -1 then'#013#010+
|
|
|
+ ' Res','ult := Result + '#039' major="'#039' + IntToStr(sMajor) + '#039+
|
|
|
+ '"'#039';'#013#010+
|
|
|
+ ' if sMinor <> -1 then'#013#010+
|
|
|
' Result := Result + '#039' minor="'#039' + IntToStr(sMinor) + '#039'"'+
|
|
|
- #039';'#010+
|
|
|
- ' if sMicro <> -1 then'#010+
|
|
|
+ #039';'#013#010+
|
|
|
+ ' if sMicro <> -1 then'#013#010+
|
|
|
' Result := Result + '#039' micro="'#039' + IntToStr(sMicro) + '#039'"'+
|
|
|
- #039';'#010+
|
|
|
- ' i','f sBuild <> -1 then'#010+
|
|
|
+ #039';'#013#010+
|
|
|
+ ' if s','Build <> -1 then'#013#010+
|
|
|
' Result := Result + '#039' build="'#039' + IntToStr(sBuild) + '#039'"'+
|
|
|
- #039';'#010+
|
|
|
- #010+
|
|
|
- ' Result := Result + '#039'/>'#039';'#010+
|
|
|
- ' end;'#010+
|
|
|
- #010+
|
|
|
- 'Var'#010+
|
|
|
- ' S : String;'#010+
|
|
|
- ' i : Integer;'#010+
|
|
|
- ' D : TDependency;'#010+
|
|
|
- 'begin'#010+
|
|
|
- ' With Manifest do'#010+
|
|
|
- ' begin'#010+
|
|
|
- ' Add(Format('#039'<package name="%s','">'#039',[QuoteXml(Name)]));'#010+
|
|
|
- #010+
|
|
|
+ #039';'#013#010+
|
|
|
+ #013#010+
|
|
|
+ ' Result := Result + '#039'/>'#039';'#013#010+
|
|
|
+ ' end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ 'Var'#013#010+
|
|
|
+ ' S : String;'#013#010+
|
|
|
+ ' i : Integer;'#013#010+
|
|
|
+ ' D : TDependency;'#013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' With Manifest do'#013#010+
|
|
|
+ ' begin'#013#010+
|
|
|
+ ' Add(Format('#039'<packag','e name="%s">'#039',[QuoteXml(Name)]));'#013+
|
|
|
+ #010+
|
|
|
+ #013#010+
|
|
|
' Add('#039' '#039' + GetXMLVersionString(FVersion.Major,FVersion.Mino'+
|
|
|
- 'r,FVersion.Micro,FVersion.Build));'#010+
|
|
|
- ' AddOSes('#039' '#039',OSes);'#010+
|
|
|
- ' AddCPUs('#039' '#039',CPUs);'#010+
|
|
|
- ' Add(Format('#039' <filename>%s</filename>'#039',[QuoteXml(FileName +'+
|
|
|
- ' ZipExt)])',');'#010+
|
|
|
- ' Add(Format('#039' <author>%s</author>'#039',[QuoteXml(Author)]));'#010+
|
|
|
- ' Add(Format('#039' <license>%s</license>'#039',[QuoteXml(License)]));'+
|
|
|
+ 'r,FVersion.Micro,FVersion.Build));'#013#010+
|
|
|
+ ' AddOSes('#039' '#039',OSes);'#013#010+
|
|
|
+ ' AddCPUs('#039' '#039',CPUs);'#013#010+
|
|
|
+ ' Add(Format('#039' <filename>%s</filename>'#039',[QuoteXml(FileN','ame'+
|
|
|
+ ' + ZipExt)]));'#013#010+
|
|
|
+ ' Add(Format('#039' <author>%s</author>'#039',[QuoteXml(Author)]));'#013+
|
|
|
#010+
|
|
|
- ' if HomepageURL<>'#039#039' then'#010+
|
|
|
+ ' Add(Format('#039' <license>%s</license>'#039',[QuoteXml(License)]));'+
|
|
|
+ #013#010+
|
|
|
+ ' if HomepageURL<>'#039#039' then'#013#010+
|
|
|
' Add(Format('#039' <homepageurl>%s</homepageurl>'#039',[QuoteXml(Ho'+
|
|
|
- 'mepageURL)]));'#010+
|
|
|
- ' if Do','wnloadURL<>'#039#039' then'#010+
|
|
|
+ 'mepag','eURL)]));'#013#010+
|
|
|
+ ' if DownloadURL<>'#039#039' then'#013#010+
|
|
|
' Add(Format('#039' <downloadurl>%s</downloadurl>'#039',[QuoteXml(Do'+
|
|
|
- 'wnloadURL)]));'#010+
|
|
|
- ' Add(Format('#039' <email>%s</email>'#039',[QuoteXMl(Email)]));'#010+
|
|
|
- ' S:=Description;'#010+
|
|
|
- ' If (S<>'#039#039') then'#010+
|
|
|
- ' Add(Format('#039' <description>%s</description','>'#039',[QuoteXML('+
|
|
|
- 'S)]));'#010+
|
|
|
- ' If (Dependencies.Count>0) then'#010+
|
|
|
- ' begin'#010+
|
|
|
- ' Add('#039' <dependencies>'#039');'#010+
|
|
|
- ' for I:=0 to Dependencies.Count-1 do'#010+
|
|
|
- ' begin'#010+
|
|
|
- ' D:=Dependencies[i];'#010+
|
|
|
- ' Add('#039' <dependency>'#039');'#010+
|
|
|
- ' Ad','d(Format('#039' <package packagename="%s"/>'#039',[Quo'+
|
|
|
- 'teXML(D.Value)]));'#010+
|
|
|
- ' if not D.FVersion.Empty then'#010+
|
|
|
+ 'wnloadURL)]));'#013#010+
|
|
|
+ ' Add(Format('#039' <email>%s</email>'#039',[QuoteXMl(Email)]));'#013#010+
|
|
|
+ ' S:=Description;'#013#010+
|
|
|
+ ' If (S<>'#039#039') then'#013#010+
|
|
|
+ ' Add(Format('#039' <de','scription>%s</description>'#039',[QuoteXML('+
|
|
|
+ 'S)]));'#013#010+
|
|
|
+ ' If (Dependencies.Count>0) then'#013#010+
|
|
|
+ ' begin'#013#010+
|
|
|
+ ' Add('#039' <dependencies>'#039');'#013#010+
|
|
|
+ ' for I:=0 to Dependencies.Count-1 do'#013#010+
|
|
|
+ ' begin'#013#010+
|
|
|
+ ' D:=Dependencies[i];'#013#010+
|
|
|
+ ' Add('#039,' <dependency>'#039');'#013#010+
|
|
|
+ ' Add(Format('#039' <package packagename="%s"/>'#039',[Quote'+
|
|
|
+ 'XML(D.Value)]));'#013#010+
|
|
|
+ ' if not D.FVersion.Empty then'#013#010+
|
|
|
' Add('#039' '#039' + GetXMLVersionString(D.FVersion.Major'+
|
|
|
- ',D.FVersion.Minor,D.FVersion.Micro,D.FVersion.Build));'#010+
|
|
|
- ' AddOS','es('#039' '#039',D.OSes);'#010+
|
|
|
- ' AddCPUs('#039' '#039',D.CPUs);'#010+
|
|
|
- ' Add('#039' </dependency>'#039');'#010+
|
|
|
- ' end;'#010+
|
|
|
- ' Add('#039' </dependencies>'#039');'#010+
|
|
|
- ' end;'#010+
|
|
|
- ' Add('#039'</package>'#039');'#010+
|
|
|
- ' end;'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
- 'procedure TPackage.AddPackageVariant(APackageVariant: ','TPackageVarian'+
|
|
|
- 'ts);'#010+
|
|
|
- 'begin'#010+
|
|
|
- ' if not assigned(APackageVariant.FMasterPackage) then'#010+
|
|
|
- ' APackageVariant.FMasterPackage := Self;'#010+
|
|
|
- ' FPackageVariants.Add(APackageVariant);'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
- 'procedure TPackage.ApplyPackageVariantToCompilerOptions(ACompilerOpti',
|
|
|
- 'ons: tstrings);'#010+
|
|
|
- 'var'#010+
|
|
|
- ' i: integer;'#010+
|
|
|
- ' PackageVariants: TPackageVariants;'#010+
|
|
|
- 'begin'#010+
|
|
|
- ' for i := 0 to FPackageVariants.Count-1 do'#010+
|
|
|
- ' begin'#010+
|
|
|
- ' PackageVariants := TPackageVariants(FPackageVariants.Items[i]);'#010+
|
|
|
- ' ACompilerOptions.AddStrings(PackageVa','riants.ActivePackageVariant'+
|
|
|
- '.Options);'#010+
|
|
|
- ' end;'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
- 'procedure TPackage.SetDefaultPackageVariant;'#010+
|
|
|
- 'var'#010+
|
|
|
- ' i,j: integer;'#010+
|
|
|
- ' PackageVariants: TPackageVariants;'#010+
|
|
|
- 'begin'#010+
|
|
|
- ' for i := 0 to FPackageVariants.Count-1 do'#010+
|
|
|
- ' begin'#010+
|
|
|
- ' PackageVariants := TP','ackageVariants(FPackageVariants.Items[i]);'#010+
|
|
|
+ ',D.FVersion.Minor,D.FVersion.Micro,D.','FVersion.Build));'#013#010+
|
|
|
+ ' AddOSes('#039' '#039',D.OSes);'#013#010+
|
|
|
+ ' AddCPUs('#039' '#039',D.CPUs);'#013#010+
|
|
|
+ ' Add('#039' </dependency>'#039');'#013#010+
|
|
|
+ ' end;'#013#010+
|
|
|
+ ' Add('#039' </dependencies>'#039');'#013#010+
|
|
|
+ ' end;'#013#010+
|
|
|
+ ' Add('#039'</package>'#039');'#013#010+
|
|
|
+ ' end;'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ 'procedur','e TPackage.AddPackageVariant(APackageVariant: TPackageVarian'+
|
|
|
+ 'ts);'#013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' if not assigned(APackageVariant.FMasterPackage) then'#013#010+
|
|
|
+ ' APackageVariant.FMasterPackage := Self;'#013#010+
|
|
|
+ ' FPackageVariants.Add(APackageVariant);'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ 'procedure TPacka','ge.ApplyPackageVariantToCompilerOptions(ACompilerOpt'+
|
|
|
+ 'ions: tstrings);'#013#010+
|
|
|
+ 'var'#013#010+
|
|
|
+ ' i: integer;'#013#010+
|
|
|
+ ' PackageVariants: TPackageVariants;'#013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' for i := 0 to FPackageVariants.Count-1 do'#013#010+
|
|
|
+ ' begin'#013#010+
|
|
|
+ ' PackageVariants := TPackageVariants(FPackageV','ariants.Items[i]);'#013+
|
|
|
+ #010+
|
|
|
+ ' ACompilerOptions.AddStrings(PackageVariants.ActivePackageVariant.O'+
|
|
|
+ 'ptions);'#013#010+
|
|
|
+ ' end;'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ 'procedure TPackage.SetDefaultPackageVariant;'#013#010+
|
|
|
+ 'var'#013#010+
|
|
|
+ ' i,j: integer;'#013#010+
|
|
|
+ ' PackageVariants: TPackageVariants;'#013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' for i :','= 0 to FPackageVariants.Count-1 do'#013#010+
|
|
|
+ ' begin'#013#010+
|
|
|
+ ' PackageVariants := TPackageVariants(FPackageVariants.Items[i]);'#013+
|
|
|
+ #010+
|
|
|
' if Installer.FPackageVariantSettings.Values[PackageVariants.Name]<'+
|
|
|
- '>'#039#039' then'#010+
|
|
|
- ' PackageVariants.ActivePackageVariantName:= Installer.FPackageVar'+
|
|
|
- 'iantSettings.Values[PackageVariants.Name]'#010+
|
|
|
- ' el','se'#010+
|
|
|
+ '>'#039#039' then'#013#010+
|
|
|
+ ' PackageVariants.ActivePackageVariantNa','me:= Installer.FPackageV'+
|
|
|
+ 'ariantSettings.Values[PackageVariants.Name]'#013#010+
|
|
|
+ ' else'#013#010+
|
|
|
' PackageVariants.ActivePackageVariantName:= PackageVariants.Defau'+
|
|
|
- 'ltPackageVariantName;'#010+
|
|
|
- ' Dictionary.AddVariable(PackageVariants.Name,PackageVariants.Active'+
|
|
|
- 'PackageVariantName);'#010+
|
|
|
- ' SetUnitsOutputDir(FUnitsOutputDir+'#039'$('#039'+PackageVari','ants.n'+
|
|
|
- 'ame+'#039')'#039');'#010+
|
|
|
+ 'ltPackageVariantName;'#013#010+
|
|
|
+ ' Dictionary.AddVariable(PackageVariants.Name,PackageVariants.Acti','v'+
|
|
|
+ 'ePackageVariantName);'#013#010+
|
|
|
+ ' SetUnitsOutputDir(FUnitsOutputDir+'#039'$('#039'+PackageVariants.nam'+
|
|
|
+ 'e+'#039')'#039');'#013#010+
|
|
|
' SetPackageUnitInstallDir(FPackageUnitInstallDir+'#039'$('#039'+Packa'+
|
|
|
- 'geVariants.Name+'#039')'#039');'#010+
|
|
|
- ' // Do not add targets f the package is inherited'#010+
|
|
|
- ' if PackageVariants.MasterPackage=Self then'#010+
|
|
|
- ' for j := 0 to PackageVariants.Acti','vePackageVariant.Targets.cou'+
|
|
|
- 'nt -1 do'#010+
|
|
|
+ 'geVariants.Name+'#039')'#039');'#013#010+
|
|
|
+ ' // Do not add targets f the package is inherited'#013#010+
|
|
|
+ ' if',' PackageVariants.MasterPackage=Self then'#013#010+
|
|
|
+ ' for j := 0 to PackageVariants.ActivePackageVariant.Targets.count'+
|
|
|
+ ' -1 do'#013#010+
|
|
|
' targets.add.assign(PackageVariants.ActivePackageVariant.Target'+
|
|
|
- 's.items[j]);'#010+
|
|
|
- ' end;'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
- #010+
|
|
|
- 'procedure TPackage.LoadUnitConfigFromFile(Const AFileName: String);'#010+
|
|
|
- 'var'#010+
|
|
|
- ' L,L2 : TStrings;'#010+
|
|
|
- ' VOS : TOS;'#010,
|
|
|
- ' VCPU : TCPU;'#010+
|
|
|
- ' i,k : Integer;'#010+
|
|
|
- ' DepChecksum : Cardinal;'#010+
|
|
|
- ' DepName : String;'#010+
|
|
|
- ' D : TDependency;'#010+
|
|
|
- ' PackageVariantsStr: string;'#010+
|
|
|
- ' PackageVarName: string;'#010+
|
|
|
- ' pv: TPackageVariants;'#010+
|
|
|
- ' AnIsInheritable: boolean;'#010+
|
|
|
- 'begin'#010+
|
|
|
- ' L:=TStringList.Create;'#010+
|
|
|
- ' Tr','y'#010+
|
|
|
- ' ReadIniFile(AFileName,L);'#010+
|
|
|
- ' With L do'#010+
|
|
|
- ' begin'#010+
|
|
|
- ' Version:=Values[KeyVersion];'#010+
|
|
|
- ' InstalledChecksum:=Cardinal(StrToInt64Def(Values[KeyChecksum],'+
|
|
|
- '$ffffffff));'#010+
|
|
|
- ' VCPU:=StringToCPU(Values[KeyCPU]);'#010+
|
|
|
- ' VOS:=String','ToOS(Values[KeyOS]);'#010+
|
|
|
- ' OSes:=[VOS];'#010+
|
|
|
- ' CPUs:=[VCPU];'#010+
|
|
|
- ' L2:=TStringList.Create;'#010+
|
|
|
- ' L2.CommaText:=Values[KeyDepends];'#010+
|
|
|
- ' for i:=0 to L2.Count-1 do'#010+
|
|
|
- ' begin'#010+
|
|
|
- ' DepName:=L2[i];'#010+
|
|
|
- ' k:=Pos('#039'|'#039',D','epName);'#010+
|
|
|
- ' if k>0 then'#010+
|
|
|
- ' begin'#010+
|
|
|
- ' DepChecksum:=StrToInt(Copy(DepName,k+1,Length(DepName)'+
|
|
|
- '-k));'#010+
|
|
|
- ' DepName:=Copy(DepName,1,k-1);'#010+
|
|
|
- ' end'#010+
|
|
|
- ' else'#010+
|
|
|
- ' DepChecksum:=$ff','ffffff;'#010+
|
|
|
- ' D:=Dependencies.Add(DepName,CPUs,OSes);'#010+
|
|
|
- ' D.RequireChecksum:=DepChecksum;'#010+
|
|
|
- ' end;'#010+
|
|
|
- ' FreeAndNil(L2);'#010+
|
|
|
- ' NeedLibC:=Upcase(Values[KeyNeedLibC])='#039'Y'#039';'#010+
|
|
|
- ' IsFPMakeAddIn:=Upcase(Values[KeyAddIn]',')='#039'Y'#039';'#010+
|
|
|
- ' Flags.DelimitedText:=Values[KeyFlags];'#010+
|
|
|
- #010+
|
|
|
- ' i := 1;'#010+
|
|
|
- ' repeat'#010+
|
|
|
- ' PackageVariantsStr:=Values[KeyPackageVar+inttostr(i)];'#010+
|
|
|
- ' if PackageVariantsStr<>'#039#039' then'#010+
|
|
|
- ' begin'#010+
|
|
|
- ' k := pos('#039':'#039',PackageVari','antsStr);'#010+
|
|
|
- ' if k > 0 then'#010+
|
|
|
- ' begin'#010+
|
|
|
- ' PackageVarName:=copy(PackageVariantsStr,1,k-1);'#010+
|
|
|
+ 's.items[j]);'#013#010+
|
|
|
+ ' end;'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ #013#010+
|
|
|
+ 'procedure TPacka','ge.LoadUnitConfigFromFile(Const AFileName: String);'#013+
|
|
|
+ #010+
|
|
|
+ 'var'#013#010+
|
|
|
+ ' L,L2 : TStrings;'#013#010+
|
|
|
+ ' VOS : TOS;'#013#010+
|
|
|
+ ' VCPU : TCPU;'#013#010+
|
|
|
+ ' i,k : Integer;'#013#010+
|
|
|
+ ' DepChecksum : Cardinal;'#013#010+
|
|
|
+ ' DepName : String;'#013#010+
|
|
|
+ ' D : TDependency;'#013#010+
|
|
|
+ ' PackageVariantsStr: string;'#013#010+
|
|
|
+ ' PackageVarNam','e: string;'#013#010+
|
|
|
+ ' pv: TPackageVariants;'#013#010+
|
|
|
+ ' AnIsInheritable: boolean;'#013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' L:=TStringList.Create;'#013#010+
|
|
|
+ ' Try'#013#010+
|
|
|
+ ' ReadIniFile(AFileName,L);'#013#010+
|
|
|
+ ' With L do'#013#010+
|
|
|
+ ' begin'#013#010+
|
|
|
+ ' Version:=Values[KeyVersion];'#013#010+
|
|
|
+ ' InstalledChecksum:=Cardinal(S','trToInt64Def(Values[KeyChecksum'+
|
|
|
+ '],$ffffffff));'#013#010+
|
|
|
+ ' VCPU:=StringToCPU(Values[KeyCPU]);'#013#010+
|
|
|
+ ' VOS:=StringToOS(Values[KeyOS]);'#013#010+
|
|
|
+ ' OSes:=[VOS];'#013#010+
|
|
|
+ ' CPUs:=[VCPU];'#013#010+
|
|
|
+ ' L2:=TStringList.Create;'#013#010+
|
|
|
+ ' L2.CommaText:=Values[K','eyDepends];'#013#010+
|
|
|
+ ' for i:=0 to L2.Count-1 do'#013#010+
|
|
|
+ ' begin'#013#010+
|
|
|
+ ' DepName:=L2[i];'#013#010+
|
|
|
+ ' k:=Pos('#039'|'#039',DepName);'#013#010+
|
|
|
+ ' if k>0 then'#013#010+
|
|
|
+ ' begin'#013#010+
|
|
|
+ ' DepChecksum:=StrToInt(Copy(DepName,k+1,Length(DepN','am'+
|
|
|
+ 'e)-k));'#013#010+
|
|
|
+ ' DepName:=Copy(DepName,1,k-1);'#013#010+
|
|
|
+ ' end'#013#010+
|
|
|
+ ' else'#013#010+
|
|
|
+ ' DepChecksum:=$ffffffff;'#013#010+
|
|
|
+ ' D:=Dependencies.Add(DepName,CPUs,OSes);'#013#010+
|
|
|
+ ' D.RequireChecksum:=DepChecksum;'#013#010+
|
|
|
+ ' ',' end;'#013#010+
|
|
|
+ ' FreeAndNil(L2);'#013#010+
|
|
|
+ ' NeedLibC:=Upcase(Values[KeyNeedLibC])='#039'Y'#039';'#013#010+
|
|
|
+ ' IsFPMakeAddIn:=Upcase(Values[KeyAddIn])='#039'Y'#039';'#013#010+
|
|
|
+ ' Flags.DelimitedText:=Values[KeyFlags];'#013#010+
|
|
|
+ #013#010+
|
|
|
+ ' i := 1;'#013#010+
|
|
|
+ ' repeat'#013#010+
|
|
|
+ ' PackageVar','iantsStr:=Values[KeyPackageVar+inttostr(i)];'#013#010+
|
|
|
+ ' if PackageVariantsStr<>'#039#039' then'#013#010+
|
|
|
+ ' begin'#013#010+
|
|
|
+ ' k := pos('#039':'#039',PackageVariantsStr);'#013#010+
|
|
|
+ ' if k > 0 then'#013#010+
|
|
|
+ ' begin'#013#010+
|
|
|
+ ' PackageVarName:=copy(Packa','geVariantsStr,1,k-1);'#013#010+
|
|
|
' if PackageVarName[Length(PackageVarName)]='#039'*'#039' '+
|
|
|
- 'then'#010+
|
|
|
- ' begin'#010+
|
|
|
- ' SetLength(P','ackageVarName,Length(PackageVarName)-1)'+
|
|
|
- ';'#010+
|
|
|
- ' AnIsInheritable:=true;'#010+
|
|
|
- ' end'#010+
|
|
|
- ' else'#010+
|
|
|
- ' AnIsInheritable:=false;'#010+
|
|
|
+ 'then'#013#010+
|
|
|
+ ' begin'#013#010+
|
|
|
+ ' SetLength(PackageVarName,Length(PackageVarName)-1);'#013+
|
|
|
+ #010+
|
|
|
+ ' AnIsInheritable:=true;'#013#010+
|
|
|
+ ' ',' end'#013#010+
|
|
|
+ ' else'#013#010+
|
|
|
+ ' AnIsInheritable:=false;'#013#010+
|
|
|
' PackageVariantsStr:=copy(PackageVariantsStr,k+1,length'+
|
|
|
- '(Pa','ckageVariantsStr)-k);'#010+
|
|
|
- ' pv := Installer.AddPackageVariant(PackageVarName, AnIs'+
|
|
|
- 'Inheritable);'#010+
|
|
|
- ' AddPackageVariant(pv);'#010+
|
|
|
- #010+
|
|
|
- ' k := pos('#039','#039',PackageVariantsStr);'#010+
|
|
|
- ' while k>0 do'#010+
|
|
|
- ' ',' begin'#010+
|
|
|
- ' PackageVarName:=copy(PackageVariantsStr,1,k-1);'#010+
|
|
|
- ' PackageVariantsStr:=copy(PackageVariantsStr,k+1,le'+
|
|
|
- 'ngth(PackageVariantsStr)-k);'#010+
|
|
|
- ' pv.Add(PackageVarName);'#010+
|
|
|
- ' ','k := pos('#039','#039',PackageVariantsStr);'#010+
|
|
|
- ' end;'#010+
|
|
|
- ' pv.Add(PackageVariantsStr);'#010+
|
|
|
- ' end;'#010+
|
|
|
- ' end;'#010+
|
|
|
- ' inc(i);'#010+
|
|
|
- ' until PackageVariantsStr='#039#039';'#010+
|
|
|
- #010+
|
|
|
- ' end;'#010+
|
|
|
- ' Finally'#010+
|
|
|
- ' L.Free;'#010+
|
|
|
- ' end;'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
- 'proce','dure TPackage.SaveUnitConfigToStringList(const AStringList: TSt'+
|
|
|
- 'rings; ACPU: TCPU; AOS: TOS);'#010+
|
|
|
- 'Var'#010+
|
|
|
- ' Deps : String;'#010+
|
|
|
- ' i,j : integer;'#010+
|
|
|
- ' D : TDependency;'#010+
|
|
|
- ' p : TPackage;'#010+
|
|
|
- ' PackageVariants : TPackageVariants;'#010+
|
|
|
- ' PackageVariantsStr: string;'#010+
|
|
|
- 'begin'#010,
|
|
|
- ' with AStringList do'#010+
|
|
|
- ' begin'#010+
|
|
|
- ' Values[KeyName]:=Name;'#010+
|
|
|
- ' Values[KeyVersion]:=Version;'#010+
|
|
|
- ' // TODO Generate checksum based on PPUs'#010+
|
|
|
- ' Values[KeyChecksum]:=IntToStr(DateTimeToFileDate(Now));'#010+
|
|
|
- ' Values[KeyCPU]:=CPUToString(AC','PU);'#010+
|
|
|
- ' Values[KeyOS]:=OSToString(AOS);'#010+
|
|
|
- ' //Installer;'#010+
|
|
|
+ '(PackageVariantsStr)-k);'#013#010+
|
|
|
+ ' pv := Installer.AddPackageVariant(PackageVarName, A','n'+
|
|
|
+ 'IsInheritable);'#013#010+
|
|
|
+ ' AddPackageVariant(pv);'#013#010+
|
|
|
+ #013#010+
|
|
|
+ ' k := pos('#039','#039',PackageVariantsStr);'#013#010+
|
|
|
+ ' while k>0 do'#013#010+
|
|
|
+ ' begin'#013#010+
|
|
|
+ ' PackageVarName:=copy(PackageVariantsStr,1,k-1);'#013+
|
|
|
+ #010+
|
|
|
+ ' ',' PackageVariantsStr:=copy(PackageVariantsStr,k+1,'+
|
|
|
+ 'length(PackageVariantsStr)-k);'#013#010+
|
|
|
+ ' pv.Add(PackageVarName);'#013#010+
|
|
|
+ ' k := pos('#039','#039',PackageVariantsStr);'#013#010+
|
|
|
+ ' end;'#013#010+
|
|
|
+ ' pv.Ad','d(PackageVariantsStr);'#013#010+
|
|
|
+ ' end;'#013#010+
|
|
|
+ ' end;'#013#010+
|
|
|
+ ' inc(i);'#013#010+
|
|
|
+ ' until PackageVariantsStr='#039#039';'#013#010+
|
|
|
+ #013#010+
|
|
|
+ ' end;'#013#010+
|
|
|
+ ' Finally'#013#010+
|
|
|
+ ' L.Free;'#013#010+
|
|
|
+ ' end;'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ 'procedure TPackage.SaveUnitConfigToStringList(const AStringList: TStri'+
|
|
|
+ 'n','gs; ACPU: TCPU; AOS: TOS);'#013#010+
|
|
|
+ 'Var'#013#010+
|
|
|
+ ' Deps : String;'#013#010+
|
|
|
+ ' i,j : integer;'#013#010+
|
|
|
+ ' D : TDependency;'#013#010+
|
|
|
+ ' p : TPackage;'#013#010+
|
|
|
+ ' PackageVariants : TPackageVariants;'#013#010+
|
|
|
+ ' PackageVariantsStr: string;'#013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' with AStringList do'#013#010+
|
|
|
+ ' begin'#013#010+
|
|
|
+ ' Values[KeyName]:=','Name;'#013#010+
|
|
|
+ ' Values[KeyVersion]:=Version;'#013#010+
|
|
|
+ ' // TODO Generate checksum based on PPUs'#013#010+
|
|
|
+ ' Values[KeyChecksum]:=IntToStr(DateTimeToFileDate(Now));'#013#010+
|
|
|
+ ' Values[KeyCPU]:=CPUToString(ACPU);'#013#010+
|
|
|
+ ' Values[KeyOS]:=OSToString(AOS);'#013#010+
|
|
|
+ ' ','//Installer;'#013#010+
|
|
|
' Values[KeySourcePath]:=IncludeTrailingPathDelimiter(IncludeTrail'+
|
|
|
- 'ingPathDelimiter(Installer.BuildEngine.FStartDir)+Directory);'#010+
|
|
|
- ' Values[KeyFPMakeOptions]:=trim(Installer','.FPMakeOptionsString);'+
|
|
|
- #010+
|
|
|
- ' Deps:='#039#039';'#010+
|
|
|
- ' for i:=0 to Dependencies.Count-1 do'#010+
|
|
|
- ' begin'#010+
|
|
|
- ' D:=Dependencies[i];'#010+
|
|
|
- ' if (ACPU in D.CPUs) and (AOS in D.OSes) then'#010+
|
|
|
- ' begin'#010+
|
|
|
- ' if Deps<>'#039#039' then'#010+
|
|
|
- ' ',' Deps:=Deps+'#039','#039';'#010+
|
|
|
- ' Deps:=Deps+D.Value;'#010+
|
|
|
- ' P:=TPackage(D.Target);'#010+
|
|
|
+ 'ingPathDelimiter(Installer.BuildEngine.FStartDir)+Directory);'#013#010+
|
|
|
+ ' Values[KeyFPMakeOptions]:=trim(Installer.FPMakeOptionsString);'#013+
|
|
|
+ #010+
|
|
|
+ ' Deps:='#039#039';'#013#010+
|
|
|
+ ' ','for i:=0 to Dependencies.Count-1 do'#013#010+
|
|
|
+ ' begin'#013#010+
|
|
|
+ ' D:=Dependencies[i];'#013#010+
|
|
|
+ ' if (ACPU in D.CPUs) and (AOS in D.OSes) then'#013#010+
|
|
|
+ ' begin'#013#010+
|
|
|
+ ' if Deps<>'#039#039' then'#013#010+
|
|
|
+ ' Deps:=Deps+'#039','#039';'#013#010+
|
|
|
+ ' Dep','s:=Deps+D.Value;'#013#010+
|
|
|
+ ' P:=TPackage(D.Target);'#013#010+
|
|
|
' if assigned(P) and (P.InstalledChecksum<>$ffffffff) then'+
|
|
|
- #010+
|
|
|
- ' Deps:=Deps+'#039'|'#039'+IntToStr(P.InstalledChecksum);'#010+
|
|
|
- ' end',';'#010+
|
|
|
- ' end;'#010+
|
|
|
- ' Values[KeyDepends]:=Deps;'#010+
|
|
|
- ' if Flags.Count>0 then'#010+
|
|
|
- ' Values[KeyFlags]:=Flags.DelimitedText;'#010+
|
|
|
- ' if NeedLibC then'#010+
|
|
|
- ' Values[KeyNeedLibC]:='#039'Y'#039#010+
|
|
|
- ' else'#010+
|
|
|
- ' Values[KeyNeedLibC]:='#039'N'#039';'#010+
|
|
|
- ' if IsFPMake','AddIn then'#010+
|
|
|
- ' Values[KeyAddIn]:='#039'Y'#039#010+
|
|
|
- ' else'#010+
|
|
|
- ' Values[KeyAddIn]:='#039'N'#039';'#010+
|
|
|
- ' for i := 0 to FPackageVariants.Count-1 do'#010+
|
|
|
- ' begin'#010+
|
|
|
+ #013#010+
|
|
|
+ ' Deps:=Deps+'#039'|'#039'+IntToStr(P.InstalledChecksum);'#013+
|
|
|
+ #010+
|
|
|
+ ' end;'#013#010+
|
|
|
+ ' end;'#013#010+
|
|
|
+ ' Values[KeyD','epends]:=Deps;'#013#010+
|
|
|
+ ' if Flags.Count>0 then'#013#010+
|
|
|
+ ' Values[KeyFlags]:=Flags.DelimitedText;'#013#010+
|
|
|
+ ' if NeedLibC then'#013#010+
|
|
|
+ ' Values[KeyNeedLibC]:='#039'Y'#039#013#010+
|
|
|
+ ' else'#013#010+
|
|
|
+ ' Values[KeyNeedLibC]:='#039'N'#039';'#013#010+
|
|
|
+ ' if IsFPMakeAddIn then'#013#010+
|
|
|
+ ' Value','s[KeyAddIn]:='#039'Y'#039#013#010+
|
|
|
+ ' else'#013#010+
|
|
|
+ ' Values[KeyAddIn]:='#039'N'#039';'#013#010+
|
|
|
+ ' for i := 0 to FPackageVariants.Count-1 do'#013#010+
|
|
|
+ ' begin'#013#010+
|
|
|
' PackageVariants := TPackageVariants(FPackageVariants.Items[i'+
|
|
|
- ']);'#010+
|
|
|
- ' PackageVari','antsStr:=PackageVariants.Name;'#010+
|
|
|
- ' if PackageVariants.IsInheritable then'#010+
|
|
|
- ' PackageVariantsStr:=PackageVariantsStr+'#039'*'#039';'#010+
|
|
|
+ ']);'#013#010+
|
|
|
+ ' PackageVariantsStr:=PackageVa','riants.Name;'#013#010+
|
|
|
+ ' if PackageVariants.IsInheritable then'#013#010+
|
|
|
+ ' PackageVariantsStr:=PackageVariantsStr+'#039'*'#039';'#013#010+
|
|
|
' PackageVariantsStr := PackageVariantsStr +'#039':'#039'+Packag'+
|
|
|
- 'eVariants.DefaultPackageVariantName;'#010+
|
|
|
- ' ',' for j := 0 to PackageVariants.Count-1 do'#010+
|
|
|
+ 'eVariants.DefaultPackageVariantName;'#013#010+
|
|
|
+ ' for j := 0',' to PackageVariants.Count-1 do'#013#010+
|
|
|
' if not sametext(PackageVariants.Items[j].Name, PackageVari'+
|
|
|
- 'ants.DefaultPackageVariantName) then'#010+
|
|
|
+ 'ants.DefaultPackageVariantName) then'#013#010+
|
|
|
' PackageVariantsStr:=PackageVariantsStr+'#039','#039'+Packa'+
|
|
|
- 'geVariants.Items[j].Name;'#010,
|
|
|
- ' values[KeyPackageVar+inttostr(i+1)] := PackageVariantsStr;'#010+
|
|
|
- ' end;'#010+
|
|
|
- ' end;'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
+ 'geVariants.Items[j].Name;'#013#010+
|
|
|
+ ' v','alues[KeyPackageVar+inttostr(i+1)] := PackageVariantsStr;'+
|
|
|
+ #013#010+
|
|
|
+ ' end;'#013#010+
|
|
|
+ ' end;'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
'procedure TPackage.SaveUnitConfigToFile(Const AFileName: String;ACPU:T'+
|
|
|
- 'CPU;AOS:TOS);'#010+
|
|
|
- 'Var'#010+
|
|
|
- ' F : TFileStream;'#010+
|
|
|
- ' L : TStringList;'#010+
|
|
|
- 'begin'#010+
|
|
|
- ' F:=TFileS','tream.Create(AFileName,fmCreate);'#010+
|
|
|
- ' L:=TStringList.Create;'#010+
|
|
|
- ' try'#010+
|
|
|
- ' SaveUnitConfigToStringList(L,ACPU,AOS);'#010+
|
|
|
- ' L.SaveToStream(F);'#010+
|
|
|
- ' Finally'#010+
|
|
|
- ' L.Free;'#010+
|
|
|
- ' F.Free;'#010+
|
|
|
- ' end;'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
- #010+
|
|
|
- #010+
|
|
|
- '{**********************************************************','*********'+
|
|
|
- '*********'#010+
|
|
|
- ' TPackages'#010+
|
|
|
+ 'CPU;AOS:TOS);'#013#010+
|
|
|
+ 'Var'#013#010+
|
|
|
+ ' F : TFileStream;'#013#010+
|
|
|
+ ' L : TStringList;'#013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' F:=TFileSt','ream.Create(AFileName,fmCreate);'#013#010+
|
|
|
+ ' L:=TStringList.Create;'#013#010+
|
|
|
+ ' try'#013#010+
|
|
|
+ ' SaveUnitConfigToStringList(L,ACPU,AOS);'#013#010+
|
|
|
+ ' L.SaveToStream(F);'#013#010+
|
|
|
+ ' Finally'#013#010+
|
|
|
+ ' L.Free;'#013#010+
|
|
|
+ ' F.Free;'#013#010+
|
|
|
+ ' end;'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ #013#010+
|
|
|
+ #013#010+
|
|
|
+ '{**********************************************','*********************'+
|
|
|
+ '*********'#013#010+
|
|
|
+ ' TPackages'#013#010+
|
|
|
'**********************************************************************'+
|
|
|
- '******}'#010+
|
|
|
- #010+
|
|
|
- 'function TPackages.GetPackage(const AName : String): TPackage;'#010+
|
|
|
- 'begin'#010+
|
|
|
- ' Result:=TPackage(ItemByName(ANa','me))'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
- 'function TPackages.GetPackageItem(AIndex : Integer): TPackage;'#010+
|
|
|
- 'begin'#010+
|
|
|
- ' Result:=TPackage(Items[AIndex]);'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
- #010+
|
|
|
+ '******}'#013#010+
|
|
|
+ #013#010+
|
|
|
+ 'function TPackages.GetPackage(const AName : String): TPackage;'#013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' Result:=TPack','age(ItemByName(AName))'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ 'function TPackages.GetPackageItem(AIndex : Integer): TPackage;'#013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' Result:=TPackage(Items[AIndex]);'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ #013#010+
|
|
|
'procedure TPackages.SetPackageItem(AIndex : Integer; const AValue: TPa'+
|
|
|
- 'ckage);'#010+
|
|
|
- 'begin'#010+
|
|
|
- ' Items[AIndex]:=AValue;'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
- #010+
|
|
|
- 'fu','nction TPackages.AddPackage(const AName: String): TPackage;'#010+
|
|
|
- 'var'#010+
|
|
|
- ' i: integer;'#010+
|
|
|
- 'begin'#010+
|
|
|
- ' i := IndexOfName(AName);'#010+
|
|
|
- ' if i > -1 then'#010+
|
|
|
- ' begin'#010+
|
|
|
- ' result := PackageItems[i];'#010+
|
|
|
- ' Installer.Log(vlWarning,Format(SWarnDuplicatePackage,[AName]))'#010+
|
|
|
- ' ','end'#010+
|
|
|
- ' else'#010+
|
|
|
- ' begin'#010+
|
|
|
- ' Result:=Add as TPackage;'#010+
|
|
|
- ' Result.Name:=AName;'#010+
|
|
|
- ' end;'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
- #010+
|
|
|
+ 'ckage);'#013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' Ite','ms[AIndex]:=AValue;'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ #013#010+
|
|
|
+ 'function TPackages.AddPackage(const AName: String): TPackage;'#013#010+
|
|
|
+ 'var'#013#010+
|
|
|
+ ' i: integer;'#013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' i := IndexOfName(AName);'#013#010+
|
|
|
+ ' if i > -1 then'#013#010+
|
|
|
+ ' begin'#013#010+
|
|
|
+ ' result := PackageItems[i];'#013#010+
|
|
|
+ ' Installer.Log(vlWarning,Fo','rmat(SWarnDuplicatePackage,[AName]))'#013+
|
|
|
+ #010+
|
|
|
+ ' end'#013#010+
|
|
|
+ ' else'#013#010+
|
|
|
+ ' begin'#013#010+
|
|
|
+ ' Result:=Add as TPackage;'#013#010+
|
|
|
+ ' Result.Name:=AName;'#013#010+
|
|
|
+ ' end;'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ #013#010+
|
|
|
'{*********************************************************************'+
|
|
|
- '*******'#010+
|
|
|
- ' TCustomDefaults'#010+
|
|
|
- '***************************','*****************************************'+
|
|
|
- '********}'#010+
|
|
|
- #010+
|
|
|
- 'procedure TCustomDefaults.SetCPU(const AValue: TCPU);'#010+
|
|
|
- 'begin'#010+
|
|
|
- ' FCPU:=AValue;'#010+
|
|
|
- ' GlobalDictionary.AddVariable('#039'CPU'#039',CPUToString(FCPU));'#010+
|
|
|
- ' RecalcTarget;'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
- 'procedure TCustomDefaults.SetOpti','ons(const AValue: TStrings);'#010+
|
|
|
- 'begin'#010+
|
|
|
- ' If (AValue=Nil) or (AValue.Count=0) then'#010+
|
|
|
- ' FreeAndNil(Foptions)'#010+
|
|
|
- ' else'#010+
|
|
|
- ' Options.Assign(AValue)'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
- #010+
|
|
|
- 'function TCustomDefaults.GetBaseInstallDir: String;'#010+
|
|
|
- 'begin'#010+
|
|
|
- ' If (FBaseInstallDir<>'#039#039') then'#010+
|
|
|
- ' Re','sult:=FBaseInstallDir'#010+
|
|
|
- ' else'#010+
|
|
|
- ' if UnixPaths then'#010+
|
|
|
+ '*******'#013#010+
|
|
|
+ ' ',' TCustomDefaults'#013#010+
|
|
|
+ '**********************************************************************'+
|
|
|
+ '******}'#013#010+
|
|
|
+ #013#010+
|
|
|
+ 'procedure TCustomDefaults.SetCPU(const AValue: TCPU);'#013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' FCPU:=AValue;'#013#010+
|
|
|
+ ' GlobalDictionary.AddVariable('#039'CPU'#039',CPUToString(FCPU)',');'#013+
|
|
|
+ #010+
|
|
|
+ ' RecalcTarget;'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ 'procedure TCustomDefaults.SetOptions(const AValue: TStrings);'#013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' If (AValue=Nil) or (AValue.Count=0) then'#013#010+
|
|
|
+ ' FreeAndNil(Foptions)'#013#010+
|
|
|
+ ' else'#013#010+
|
|
|
+ ' Options.Assign(AValue)'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ #013#010+
|
|
|
+ 'function TCustomDefaults.','GetBaseInstallDir: String;'#013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' If (FBaseInstallDir<>'#039#039') then'#013#010+
|
|
|
+ ' Result:=FBaseInstallDir'#013#010+
|
|
|
+ ' else'#013#010+
|
|
|
+ ' if UnixPaths then'#013#010+
|
|
|
' Result:=Prefix +'#039'lib'#039' + PathDelim + '#039'fpc'#039' + Path'+
|
|
|
- 'Delim + FCompilerVersion + PathDelim'#010+
|
|
|
- ' else'#010+
|
|
|
- ' Result:=Prefix;'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
- #010+
|
|
|
- 'function TCustomDefaults.GetBinInstallDir: String;'#010+
|
|
|
- 'begin'#010+
|
|
|
- ' I','f (FBinInstallDir<>'#039#039') then'#010+
|
|
|
- ' Result:=FBinInstallDir'#010+
|
|
|
- ' else'#010+
|
|
|
- ' If UnixPaths then'#010+
|
|
|
- ' Result:=Prefix+'#039'bin'#039#010+
|
|
|
- ' else'#010+
|
|
|
- ' Result:=BaseInstallDir+'#039'bin'#039'+pathdelim+MakeTargetString('+
|
|
|
- 'Defaults.cpu, Defaults.OS);'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
- #010+
|
|
|
- 'function TCustomDefault','s.GetCompiler: String;'#010+
|
|
|
- 'begin'#010+
|
|
|
- ' If (FCompiler<>'#039#039') then'#010+
|
|
|
- ' Result:=FCompiler'#010+
|
|
|
- ' else'#010+
|
|
|
- ' Result:='#039'fpc'#039';'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
- #010+
|
|
|
- 'function TCustomDefaults.GetDocInstallDir: String;'#010+
|
|
|
- 'begin'#010+
|
|
|
- ' If (FDocInstallDir<>'#039#039') then'#010+
|
|
|
- ' Result:=FDocInstallDir'#010+
|
|
|
- ' else'#010+
|
|
|
- ' If U','nixPaths then'#010+
|
|
|
- ' Result:=Prefix+'#039'share'#039'+PathDelim+'#039'doc'#039#010+
|
|
|
- ' else'#010+
|
|
|
- ' Result:=BaseInstallDir+'#039'docs'#039';'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
- #010+
|
|
|
- 'function TCustomDefaults.GetExamplesInstallDir: String;'#010+
|
|
|
- 'begin'#010+
|
|
|
- ' If (FExamplesInstallDir<>'#039#039') then'#010+
|
|
|
- ' Result:=FExamplesInstallDi','r'#010+
|
|
|
- ' else'#010+
|
|
|
- ' If UnixPaths then'#010+
|
|
|
- ' Result:=Prefix+'#039'share'#039'+PathDelim+'#039'doc'#039#010+
|
|
|
- ' else'#010+
|
|
|
- ' Result:=BaseInstallDir+'#039'examples'#039';'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
- 'function TCustomDefaults.GetOptions: TStrings;'#010+
|
|
|
- 'begin'#010+
|
|
|
- ' If (FOptions=Nil) then'#010+
|
|
|
- ' FOptions:=TStringList.Crea','te;'#010+
|
|
|
- ' Result:=FOptions;'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
- #010+
|
|
|
- 'function TCustomDefaults.GetUnitInstallDir: String;'#010+
|
|
|
- 'begin'#010+
|
|
|
- ' result := FixPath(GlobalDictionary.ReplaceStrings(FUnitInstallDir), '+
|
|
|
- 'True);'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
- #010+
|
|
|
- 'function TCustomDefaults.GetLocalUnitDir: String;'#010+
|
|
|
- 'begin'#010+
|
|
|
- ' Result:=F','LocalUnitDir;'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
- 'function TCustomDefaults.GetFPDocOutputDir: String;'#010+
|
|
|
- 'begin'#010+
|
|
|
- ' If (FFPDocOutputDir<>'#039#039') then'#010+
|
|
|
- ' Result:=FixPath(FFPDocOutputDir, True)'#010+
|
|
|
- ' else'#010+
|
|
|
- ' Result:=FixPath('#039'.'#039'+PathDelim+'#039'docs'#039', True);'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
- 'function TCustomDefaults.','GetBuildCPU: TCpu;'#010+
|
|
|
- 'begin'#010+
|
|
|
- ' result := StringToCPU({$I %FPCTARGETCPU%});'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
- 'function TCustomDefaults.GetBuildOS: TOS;'#010+
|
|
|
- 'begin'#010+
|
|
|
- ' result := StringToOS({$I %FPCTARGETOS%});'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
- 'function TCustomDefaults.GetBuildString: String;'#010+
|
|
|
- 'begin'#010+
|
|
|
- ' result :','= MakeTargetString(BuildCPU, BuildOS);'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
- 'function TCustomDefaults.GetGlobalUnitDir: String;'#010+
|
|
|
- 'begin'#010+
|
|
|
- ' If (FGlobalUnitDir<>'#039#039') then'#010+
|
|
|
- ' Result:=FGlobalUnitDir'#010+
|
|
|
- ' else'#010+
|
|
|
- ' Result:=UnitInstallDir;'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
- #010+
|
|
|
- 'procedure TCustomDefaults.SetLocalUnit','Dir(const AValue: String);'#010+
|
|
|
- 'begin'#010+
|
|
|
- ' // Use ExpandFileName to support ~/ expansion'#010+
|
|
|
- ' if AValue<>'#039#039' then'#010+
|
|
|
+ 'Delim + FCompilerVersion + PathDelim'#013#010+
|
|
|
+ ' else'#013#010+
|
|
|
+ ' Resu','lt:=Prefix;'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ #013#010+
|
|
|
+ 'function TCustomDefaults.GetBinInstallDir: String;'#013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' If (FBinInstallDir<>'#039#039') then'#013#010+
|
|
|
+ ' Result:=FBinInstallDir'#013#010+
|
|
|
+ ' else'#013#010+
|
|
|
+ ' If UnixPaths then'#013#010+
|
|
|
+ ' Result:=Prefix+'#039'bin'#039#013#010+
|
|
|
+ ' else'#013#010+
|
|
|
+ ' Result:=BaseInstallDir+',#039'bin'#039'+pathdelim+MakeTargetString('+
|
|
|
+ 'Defaults.cpu, Defaults.OS);'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ #013#010+
|
|
|
+ 'function TCustomDefaults.GetCompiler: String;'#013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' If (FCompiler<>'#039#039') then'#013#010+
|
|
|
+ ' Result:=FCompiler'#013#010+
|
|
|
+ ' else'#013#010+
|
|
|
+ ' Result:='#039'fpc'#039';'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ #013#010+
|
|
|
+ 'function TCustomDefaults.G','etDocInstallDir: String;'#013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' If (FDocInstallDir<>'#039#039') then'#013#010+
|
|
|
+ ' Result:=FDocInstallDir'#013#010+
|
|
|
+ ' else'#013#010+
|
|
|
+ ' If UnixPaths then'#013#010+
|
|
|
+ ' Result:=Prefix+'#039'share'#039'+PathDelim+'#039'doc'#039#013#010+
|
|
|
+ ' else'#013#010+
|
|
|
+ ' Result:=BaseInstallDir+'#039'docs'#039';'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ #013#010+
|
|
|
+ 'function TCu','stomDefaults.GetExamplesInstallDir: String;'#013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' If (FExamplesInstallDir<>'#039#039') then'#013#010+
|
|
|
+ ' Result:=FExamplesInstallDir'#013#010+
|
|
|
+ ' else'#013#010+
|
|
|
+ ' If UnixPaths then'#013#010+
|
|
|
+ ' Result:=Prefix+'#039'share'#039'+PathDelim+'#039'doc'#039#013#010+
|
|
|
+ ' else'#013#010+
|
|
|
+ ' Result:=BaseInstallDir+'#039'e','xamples'#039';'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ 'function TCustomDefaults.GetOptions: TStrings;'#013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' If (FOptions=Nil) then'#013#010+
|
|
|
+ ' FOptions:=TStringList.Create;'#013#010+
|
|
|
+ ' Result:=FOptions;'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ #013#010+
|
|
|
+ 'function TCustomDefaults.GetUnitInstallDir: String;'#013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' result := Fi','xPath(GlobalDictionary.ReplaceStrings(FUnitInstallDir)'+
|
|
|
+ ', False);'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ #013#010+
|
|
|
+ 'function TCustomDefaults.GetLocalUnitDir: String;'#013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' Result:=FLocalUnitDir;'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ 'function TCustomDefaults.GetFPDocOutputDir: String;'#013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' If (FFPDocO','utputDir<>'#039#039') then'#013#010+
|
|
|
+ ' Result:=FixPath(FFPDocOutputDir, True)'#013#010+
|
|
|
+ ' else'#013#010+
|
|
|
+ ' Result:=FixPath('#039'.'#039'+PathDelim+'#039'docs'#039', True);'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ 'function TCustomDefaults.GetBuildCPU: TCpu;'#013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' result := StringToCPU({$I %FPCTARGETCPU%});'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ 'fun','ction TCustomDefaults.GetBuildOS: TOS;'#013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' result := StringToOS({$I %FPCTARGETOS%});'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ 'function TCustomDefaults.GetBuildString: String;'#013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' result := MakeTargetString(BuildCPU, BuildOS);'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ 'function TCustomDefaults.','GetGlobalUnitDir: String;'#013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' If (FGlobalUnitDir<>'#039#039') then'#013#010+
|
|
|
+ ' Result:=FGlobalUnitDir'#013#010+
|
|
|
+ ' else'#013#010+
|
|
|
+ ' Result:=UnitInstallDir;'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ #013#010+
|
|
|
+ 'procedure TCustomDefaults.SetLocalUnitDir(const AValue: String);'#013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' // Use ExpandFileName to',' support ~/ expansion'#013#010+
|
|
|
+ ' if AValue<>'#039#039' then'#013#010+
|
|
|
' FLocalUnitDir:=IncludeTrailingPathDelimiter(ExpandFileName(AValue)'+
|
|
|
- ')'#010+
|
|
|
- ' else'#010+
|
|
|
- ' FLocalUnitDir:='#039#039';'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
- #010+
|
|
|
- 'procedure TCustomDefaults.Set','GlobalUnitDir(const AValue: String);'#010+
|
|
|
- 'begin'#010+
|
|
|
- ' // Use ExpandFileName to support ~/ expansion'#010+
|
|
|
- ' if AValue<>'#039#039' then'#010+
|
|
|
+ ')'#013#010+
|
|
|
+ ' else'#013#010+
|
|
|
+ ' FLocalUnitDir:='#039#039';'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ #013#010+
|
|
|
+ 'procedure TCustomDefaults.SetGlobalUnitDir(const AValue: String);'#013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' // U','se ExpandFileName to support ~/ expansion'#013#010+
|
|
|
+ ' if AValue<>'#039#039' then'#013#010+
|
|
|
' FGlobalUnitDir:=IncludeTrailingPathDelimiter(ExpandFileName(AValue'+
|
|
|
- '))'#010+
|
|
|
- ' else'#010+
|
|
|
- ' FGlobalUnitDir:='#039#039';'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
- 'procedure TCustomD','efaults.IntSetBaseInstallDir(const AValue: String)'+
|
|
|
- ';'#010+
|
|
|
- 'begin'#010+
|
|
|
- ' if AValue<>'#039#039' then'#010+
|
|
|
- ' FBaseInstallDir:=IncludeTrailingPathDelimiter(AValue)'#010+
|
|
|
- ' else'#010+
|
|
|
- ' FBaseInstallDir:='#039#039';'#010+
|
|
|
+ '))'#013#010+
|
|
|
+ ' else'#013#010+
|
|
|
+ ' FGlobalUnitDir:='#039#039';'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ 'procedure TCustomDefaults.IntSetBaseInstallDir(const AValue:',' String)'+
|
|
|
+ ';'#013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' if AValue<>'#039#039' then'#013#010+
|
|
|
+ ' FBaseInstallDir:=IncludeTrailingPathDelimiter(AValue)'#013#010+
|
|
|
+ ' else'#013#010+
|
|
|
+ ' FBaseInstallDir:='#039#039';'#013#010+
|
|
|
' GlobalDictionary.AddVariable('#039'baseinstalldir'#039',BaseInstallDir'+
|
|
|
- ');'#010+
|
|
|
- ' Glob','alDictionary.AddVariable('#039'bininstalldir'#039',BinInstallDir'+
|
|
|
- ');'#010+
|
|
|
- ' BinInstallDir:='#039#039';'#010+
|
|
|
- ' ExamplesInstallDir:='#039#039';'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
- #010+
|
|
|
- 'procedure TCustomDefaults.SetBaseInstallDir(const AValue: String);'#010+
|
|
|
- 'begin'#010+
|
|
|
- ' // There must be a possibility to skip ExpandFileName.',' So that the'+
|
|
|
- ' files'#010+
|
|
|
- ' // can be written into an archive with a relative path.'#010+
|
|
|
- ' if AValue<>'#039#039' then'#010+
|
|
|
- ' // Use ExpandFileName to support ~/ expansion'#010+
|
|
|
- ' IntSetBaseInstallDir(ExpandFileName(AValue))'#010+
|
|
|
- ' else'#010+
|
|
|
- ' IntSetBaseInstallDir(AValue);'#010+
|
|
|
- 'en','d;'#010+
|
|
|
- #010+
|
|
|
- #010+
|
|
|
- 'procedure TCustomDefaults.SetOS(const AValue: TOS);'#010+
|
|
|
- 'begin'#010+
|
|
|
- ' FOS:=AValue;'#010+
|
|
|
- ' GlobalDictionary.AddVariable('#039'OS'#039',OSToString(FOS));'#010+
|
|
|
- ' Recalctarget;'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
- #010+
|
|
|
- 'procedure TCustomDefaults.SetPrefix(const AValue: String);'#010+
|
|
|
- 'begin'#010+
|
|
|
- ' if FPrefix=AValue ','then exit;'#010+
|
|
|
- ' // Use ExpandFileName to support ~/ expansion'#010+
|
|
|
- ' if AValue<>'#039#039' then'#010+
|
|
|
- ' FPrefix:=IncludeTrailingPathDelimiter(ExpandFileName(AValue))'#010+
|
|
|
- ' else'#010+
|
|
|
- ' FPrefix:='#039#039';'#010+
|
|
|
- ' GlobalDictionary.AddVariable('#039'prefix'#039',Prefix);'#010+
|
|
|
+ ');'#013#010+
|
|
|
+ ' GlobalDictionary.AddVariable('#039'bininstal','ldir'#039',BinInstallDir'+
|
|
|
+ ');'#013#010+
|
|
|
+ ' BinInstallDir:='#039#039';'#013#010+
|
|
|
+ ' ExamplesInstallDir:='#039#039';'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ #013#010+
|
|
|
+ 'procedure TCustomDefaults.SetBaseInstallDir(const AValue: String);'#013+
|
|
|
+ #010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' // There must be a possibility to skip ExpandFileName. So that the f'+
|
|
|
+ 'iles'#013#010+
|
|
|
+ ' // ca','n be written into an archive with a relative path.'#013#010+
|
|
|
+ ' if AValue<>'#039#039' then'#013#010+
|
|
|
+ ' // Use ExpandFileName to support ~/ expansion'#013#010+
|
|
|
+ ' IntSetBaseInstallDir(ExpandFileName(AValue))'#013#010+
|
|
|
+ ' else'#013#010+
|
|
|
+ ' IntSetBaseInstallDir(AValue);'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ #013#010+
|
|
|
+ 'procedure TC','ustomDefaults.SetOS(const AValue: TOS);'#013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' FOS:=AValue;'#013#010+
|
|
|
+ ' GlobalDictionary.AddVariable('#039'OS'#039',OSToString(FOS));'#013#010+
|
|
|
+ ' Recalctarget;'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ #013#010+
|
|
|
+ 'procedure TCustomDefaults.SetPrefix(const AValue: String);'#013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' if FPrefix=AValue then ex','it;'#013#010+
|
|
|
+ ' // Use ExpandFileName to support ~/ expansion'#013#010+
|
|
|
+ ' if AValue<>'#039#039' then'#013#010+
|
|
|
+ ' FPrefix:=IncludeTrailingPathDelimiter(ExpandFileName(AValue))'#013#010+
|
|
|
+ ' else'#013#010+
|
|
|
+ ' FPrefix:='#039#039';'#013#010+
|
|
|
+ ' GlobalDictionary.AddVariable('#039'prefix'#039',Prefix);'#013#010+
|
|
|
' GlobalDictionary.Ad','dVariable('#039'bininstalldir'#039',BinInstallDir'+
|
|
|
- ');'#010+
|
|
|
- ' BaseInstallDir:='#039#039';'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
- #010+
|
|
|
- 'procedure TCustomDefaults.SetTarget(const AValue: String);'#010+
|
|
|
- 'Var'#010+
|
|
|
- ' P : Integer;'#010+
|
|
|
- 'begin'#010+
|
|
|
- ' if FTarget<>AValue then'#010+
|
|
|
- ' begin'#010+
|
|
|
- ' P:=Pos('#039'-'#039',AValue);'#010+
|
|
|
- ' If (P<>0) then'#010+
|
|
|
- ' ',' begin'#010+
|
|
|
- ' FOS:=StringToOS(System.Copy(Avalue,P+1,Length(AValue)-P));'#010+
|
|
|
- ' GlobalDictionary.AddVariable('#039'OS'#039',OSToString(FOS));'#010+
|
|
|
- ' FCPU:=StringToCPU(System.Copy(Avalue,1,P-1));'#010+
|
|
|
- ' GlobalDictionary.AddVariable('#039'C','PU'#039',CPUToString(FCP'+
|
|
|
- 'U));'#010+
|
|
|
- ' end'#010+
|
|
|
- ' else'#010+
|
|
|
- ' FOS:=StringToOS(AValue);'#010+
|
|
|
- ' FTarget:=AValue;'#010+
|
|
|
- ' GlobalDictionary.AddVariable('#039'target'#039',Target);'#010+
|
|
|
- ' end;'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
- 'procedure TCustomDefaults.SetUnitInstallDir(const AValue: String);'#010+
|
|
|
- 'be','gin'#010+
|
|
|
- ' if AValue<>'#039#039' then'#010+
|
|
|
- ' FUnitInstallDir:=IncludeTrailingPathDelimiter(AValue)'#010+
|
|
|
- ' else'#010+
|
|
|
- ' FUnitInstallDir:='#039#039';'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
- #010+
|
|
|
- 'procedure TCustomDefaults.RecalcTarget;'#010+
|
|
|
- 'begin'#010+
|
|
|
- ' Ftarget:=MakeTargetString(FCPU,FOS);'#010+
|
|
|
- ' GlobalDictionary.AddVariable('#039't','arget'#039',Target);'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
- 'function TCustomDefaults.CmdLineOptions: String;'#010+
|
|
|
- 'begin'#010+
|
|
|
- ' If Haveoptions then'#010+
|
|
|
- ' Result:=OptionListToString(FOptions);'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
- #010+
|
|
|
- 'constructor TCustomDefaults.Create;'#010+
|
|
|
- 'begin'#010+
|
|
|
- ' InitDefaults;'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
- #010+
|
|
|
- 'procedure TCustomDefaults.I','nitDefaults;'#010+
|
|
|
- 'begin'#010+
|
|
|
- '{$ifdef unix}'#010+
|
|
|
- ' UnixPaths:=True;'#010+
|
|
|
- '{$else}'#010+
|
|
|
- ' UnixPaths:=False;'#010+
|
|
|
- '{$endif}'#010+
|
|
|
- ' FNoFPCCfg:=False;'#010+
|
|
|
- ' FCPU:=cpuNone;'#010+
|
|
|
- ' FOS:=osNone;'#010+
|
|
|
- ' FUnitInstallDir:='#039'$(BaseInstallDir)units/$(target)/$(packagename'+
|
|
|
- ')'#039';'#010+
|
|
|
- ' FBuildMode:=bmOneByOne;'#010+
|
|
|
- ' F','ThreadsAmount:=-1;'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
- 'function TCustomDefaults.HaveOptions: Boolean;'#010+
|
|
|
- 'begin'#010+
|
|
|
- ' Result:=Assigned(FOptions);'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
- 'function TCustomDefaults.IsBuildDifferentFromTarget: boolean;'#010+
|
|
|
- 'begin'#010+
|
|
|
- ' result := IsDifferentFromBuild(CPU,OS);'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
- #010+
|
|
|
- 'procedure',' TCustomDefaults.LocalInit(Const AFileName : String);'#010+
|
|
|
- 'Var'#010+
|
|
|
- ' FN : String;'#010+
|
|
|
- 'begin'#010+
|
|
|
- ' FN:=AFileName;'#010+
|
|
|
- ' If (FN='#039#039') then'#010+
|
|
|
- ' begin'#010+
|
|
|
- ' // Environment variable.'#010+
|
|
|
- ' FN:=GetEnvironmentVariable('#039'FPMAKECFG'#039');'#010+
|
|
|
- ' If (FN<>'#039#039') then'#010+
|
|
|
- ' If not FileExis','ts(FN) then'#010+
|
|
|
- ' FN:='#039#039';'#010+
|
|
|
- ' // User config file fpmake.cfg'#010+
|
|
|
- ' If (FN='#039#039') then'#010+
|
|
|
- ' begin'#010+
|
|
|
- ' FN:=GetAppConfigFile(False);'#010+
|
|
|
- ' If Not FileExists(FN) then'#010+
|
|
|
- ' FN:='#039#039';'#010+
|
|
|
- ' end;'#010+
|
|
|
- ' // Global config file fpmake.cfg'#010+
|
|
|
- ' If (FN='#039#039,') then'#010+
|
|
|
- ' begin'#010+
|
|
|
- ' FN:=GetAppConfigFile(True);'#010+
|
|
|
- ' If Not FileExists(FN) then'#010+
|
|
|
- ' FN:='#039#039';'#010+
|
|
|
- ' end;'#010+
|
|
|
- ' end;'#010+
|
|
|
- ' If (FN<>'#039#039') and FileExists(FN) then'#010+
|
|
|
- ' LoadFromFile(FN);'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
- #010+
|
|
|
- 'procedure TCustomDefaults.CompilerDefaults;'#010+
|
|
|
- '{$ifdef',' HAS_UNIT_PROCESS}'#010+
|
|
|
- 'var'#010+
|
|
|
- ' infoSL : TStringList;'#010+
|
|
|
- '{$endif HAS_UNIT_PROCESS}'#010+
|
|
|
- 'begin'#010+
|
|
|
- ' if (CPU=cpuNone) or (OS=osNone) or (FCompilerVersion='#039#039') then'#010+
|
|
|
- ' begin'#010+
|
|
|
- '{$ifdef HAS_UNIT_PROCESS}'#010+
|
|
|
- ' // Detect compiler version/target from -i option'#010+
|
|
|
- ' ','infosl:=TStringList.Create;'#010+
|
|
|
- ' infosl.Delimiter:='#039' '#039';'#010+
|
|
|
- ' infosl.DelimitedText:=GetCompilerInfo(GetCompiler,'#039'-iVTPTO'#039+
|
|
|
- ');'#010+
|
|
|
- ' if infosl.Count<>3 then'#010+
|
|
|
- ' Raise EInstallerError.Create(SErrInvalidFPCInfo);'#010+
|
|
|
- ' if FCompilerVersion='#039,#039' then'#010+
|
|
|
- ' FCompilerVersion:=infosl[0];'#010+
|
|
|
- ' if CPU=cpuNone then'#010+
|
|
|
- ' CPU:=StringToCPU(infosl[1]);'#010+
|
|
|
- ' if OS=osNone then'#010+
|
|
|
- ' OS:=StringToOS(infosl[2]);'#010+
|
|
|
- '{$else HAS_UNIT_PROCESS}'#010+
|
|
|
- ' // Defaults taken from compiler used to bui','ld fpmake'#010+
|
|
|
- ' if CPU=cpuNone then'#010+
|
|
|
- ' CPU:=StringToCPU({$I %FPCTARGETCPU%});'#010+
|
|
|
- ' if OS=osNone then'#010+
|
|
|
- ' OS:=StringToOS({$I %FPCTARGETOS%});'#010+
|
|
|
- ' if FCompilerVersion='#039#039' then'#010+
|
|
|
- ' FCompilerVersion:={$I %FPCVERSION%};'#010+
|
|
|
- '{$endif HA','S_UNIT_PROCESS}'#010+
|
|
|
- ' end;'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
- #010+
|
|
|
- 'procedure TCustomDefaults.LoadFromFile(Const AFileName: String);'#010+
|
|
|
- 'Var'#010+
|
|
|
- ' F : TFileStream;'#010+
|
|
|
- 'begin'#010+
|
|
|
- ' F:=TFileStream.Create(AFileName,fmOpenRead);'#010+
|
|
|
- ' Try'#010+
|
|
|
- ' LoadFromStream(F);'#010+
|
|
|
- ' Finally'#010+
|
|
|
- ' F.Free;'#010+
|
|
|
- ' end;'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
- #010+
|
|
|
- 'pr','ocedure TCustomDefaults.SaveToFile(Const AFileName: String);'#010+
|
|
|
- 'Var'#010+
|
|
|
- ' F : TFileStream;'#010+
|
|
|
- 'begin'#010+
|
|
|
- ' F:=TFileStream.Create(AFileName,fmCreate);'#010+
|
|
|
- ' Try'#010+
|
|
|
- ' SaveToStream(F);'#010+
|
|
|
- ' Finally'#010+
|
|
|
- ' F.Free;'#010+
|
|
|
- ' end;'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
- #010+
|
|
|
- 'procedure TCustomDefaults.SaveToStream(S :',' TStream);'#010+
|
|
|
- 'Var'#010+
|
|
|
- ' L : TStringList;'#010+
|
|
|
- 'begin'#010+
|
|
|
- ' L:=TStringList.Create;'#010+
|
|
|
- ' try'#010+
|
|
|
- ' With L do'#010+
|
|
|
- ' begin'#010+
|
|
|
- ' Values[KeyArchive]:=FArchive;'#010+
|
|
|
- ' Values[KeyCompiler]:=FCompiler;'#010+
|
|
|
- ' Values[KeyCopy]:=FCopy;'#010+
|
|
|
- ' Values[KeyMkDir]:=FMkDir;'#010+
|
|
|
- ' V','alues[KeyMove]:=FMove;'#010+
|
|
|
- ' Values[KeyOptions]:=CmdLineOptions;'#010+
|
|
|
- ' Values[KeyCPU]:=CPUToString(FCPU);'#010+
|
|
|
- ' Values[KeyOS]:=OSToString(FOS);'#010+
|
|
|
- ' Values[KeyMode]:=ModeToString(FMode);'#010+
|
|
|
- ' Values[KeyLocalUnitDir]:=FLocalUnitDir;'#010+
|
|
|
- ' ','Values[KeyGlobalUnitDir]:=FGlobalUnitDir;'#010+
|
|
|
- ' Values[KeyPrefix]:=FPrefix;'#010+
|
|
|
- ' Values[KeyBaseInstallDir]:=FBaseInstallDir;'#010+
|
|
|
- ' Values[KeyUnitInstallDir]:=FUnitInstallDir;'#010+
|
|
|
- ' Values[KeyBinInstallDir]:=FBinInstallDir;'#010+
|
|
|
- ' Values[Key','DocInstallDir]:=FDocInstallDir;'#010+
|
|
|
- ' Values[KeyExamplesInstallDir]:=FExamplesInstallDir;'#010+
|
|
|
- ' Values[KeyRemove]:=FRemove;'#010+
|
|
|
- ' Values[KeyRemoveDir]:=FRemoveDir;'#010+
|
|
|
- ' Values[KeyRemoveTree]:=FRemoveTree;'#010+
|
|
|
- ' Values[KeyTarget]:=FTarget;'#010,
|
|
|
- ' if FNoFPCCfg then'#010+
|
|
|
- ' Values[KeyNoFPCCfg]:='#039'Y'#039';'#010+
|
|
|
- ' if FUseEnvironment then'#010+
|
|
|
- ' Values[KeyUseEnv]:='#039'Y'#039';'#010+
|
|
|
- ' if FInstallExamples then'#010+
|
|
|
- ' Values[KeyInstallExamples]:='#039'Y'#039';'#010+
|
|
|
- ' if FSkipCrossPrograms then'#010+
|
|
|
- ' Value','s[KeySkipCrossProdrams]:='#039'Y'#039';'#010+
|
|
|
- ' end;'#010+
|
|
|
- ' L.SaveToStream(S);'#010+
|
|
|
- ' Finally'#010+
|
|
|
- ' L.Free;'#010+
|
|
|
- ' end;'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
- #010+
|
|
|
- 'procedure TCustomDefaults.LoadFromStream(S: TStream);'#010+
|
|
|
- 'Var'#010+
|
|
|
- ' L : TStrings;'#010+
|
|
|
- ' Line : String;'#010+
|
|
|
- ' I,P,PC : Integer;'#010+
|
|
|
- 'begin'#010+
|
|
|
- ' L:=TStringList.Create',';'#010+
|
|
|
- ' Try'#010+
|
|
|
- ' L.LoadFromStream(S);'#010+
|
|
|
- ' // Fix lines.'#010+
|
|
|
- ' For I:=L.Count-1 downto 0 do'#010+
|
|
|
- ' begin'#010+
|
|
|
- ' Line:=L[I];'#010+
|
|
|
- ' P:=Pos('#039'='#039',Line);'#010+
|
|
|
- ' PC:=Pos('#039';'#039',Line); // Comment line.'#010+
|
|
|
- ' If (P=0) or ((PC<>0) and (PC<P)) then'#010+
|
|
|
- ' L.Delet','e(I)'#010+
|
|
|
- ' else'#010+
|
|
|
+ ');'#013#010+
|
|
|
+ ' BaseInstallDir:='#039#039';'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ #013#010+
|
|
|
+ 'procedure TCustomDefaults.SetTarget(const AValue: String);'#013#010+
|
|
|
+ 'Var'#013#010+
|
|
|
+ ' P : Integer;'#013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' if FTarget<>AValue then'#013#010+
|
|
|
+ ' begin'#013#010+
|
|
|
+ ' P:=Pos('#039'-'#039',AValue);'#013#010+
|
|
|
+ ' If (P','<>0) then'#013#010+
|
|
|
+ ' begin'#013#010+
|
|
|
+ ' FOS:=StringToOS(System.Copy(Avalue,P+1,Length(AValue)-P));'#013+
|
|
|
+ #010+
|
|
|
+ ' GlobalDictionary.AddVariable('#039'OS'#039',OSToString(FOS));'#013+
|
|
|
+ #010+
|
|
|
+ ' FCPU:=StringToCPU(System.Copy(Avalue,1,P-1));'#013#010+
|
|
|
+ ' GlobalDictiona','ry.AddVariable('#039'CPU'#039',CPUToString(FCP'+
|
|
|
+ 'U));'#013#010+
|
|
|
+ ' end'#013#010+
|
|
|
+ ' else'#013#010+
|
|
|
+ ' FOS:=StringToOS(AValue);'#013#010+
|
|
|
+ ' FTarget:=AValue;'#013#010+
|
|
|
+ ' GlobalDictionary.AddVariable('#039'target'#039',Target);'#013#010+
|
|
|
+ ' end;'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ 'procedure TCustomDefaults.SetUnitInstallDir','(const AValue: String);'#013+
|
|
|
+ #010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' if AValue<>'#039#039' then'#013#010+
|
|
|
+ ' FUnitInstallDir:=IncludeTrailingPathDelimiter(AValue)'#013#010+
|
|
|
+ ' else'#013#010+
|
|
|
+ ' FUnitInstallDir:='#039#039';'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ #013#010+
|
|
|
+ 'procedure TCustomDefaults.RecalcTarget;'#013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' Ftarget:=MakeTargetString(FCPU,FO','S);'#013#010+
|
|
|
+ ' GlobalDictionary.AddVariable('#039'target'#039',Target);'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ 'function TCustomDefaults.CmdLineOptions: String;'#013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' If Haveoptions then'#013#010+
|
|
|
+ ' Result:=OptionListToString(FOptions);'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ #013#010+
|
|
|
+ 'constructor TCustomDefaults.Create;'#013#010+
|
|
|
+ 'begin'#013#010,
|
|
|
+ ' InitDefaults;'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ #013#010+
|
|
|
+ 'procedure TCustomDefaults.InitDefaults;'#013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ '{$ifdef unix}'#013#010+
|
|
|
+ ' UnixPaths:=True;'#013#010+
|
|
|
+ '{$else}'#013#010+
|
|
|
+ ' UnixPaths:=False;'#013#010+
|
|
|
+ '{$endif}'#013#010+
|
|
|
+ ' FNoFPCCfg:=False;'#013#010+
|
|
|
+ ' FCPU:=cpuNone;'#013#010+
|
|
|
+ ' FOS:=osNone;'#013#010+
|
|
|
+ ' FUnitInstallDir:='#039'$(BaseInstallDi','r)units/$(target)/$(packagena'+
|
|
|
+ 'me)'#039';'#013#010+
|
|
|
+ ' FBuildMode:=bmOneByOne;'#013#010+
|
|
|
+ ' FThreadsAmount:=-1;'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ 'function TCustomDefaults.HaveOptions: Boolean;'#013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' Result:=Assigned(FOptions);'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ 'function TCustomDefaults.IsBuildDifferentFromTarget:',' boolean;'#013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' result := IsDifferentFromBuild(CPU,OS);'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ #013#010+
|
|
|
+ 'procedure TCustomDefaults.LocalInit(Const AFileName : String);'#013#010+
|
|
|
+ 'Var'#013#010+
|
|
|
+ ' FN : String;'#013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' FN:=AFileName;'#013#010+
|
|
|
+ ' If (FN='#039#039') then'#013#010+
|
|
|
+ ' begin'#013#010+
|
|
|
+ ' // Environment variable.'#013,#010+
|
|
|
+ ' FN:=GetEnvironmentVariable('#039'FPMAKECFG'#039');'#013#010+
|
|
|
+ ' If (FN<>'#039#039') then'#013#010+
|
|
|
+ ' If not FileExists(FN) then'#013#010+
|
|
|
+ ' FN:='#039#039';'#013#010+
|
|
|
+ ' // User config file fpmake.cfg'#013#010+
|
|
|
+ ' If (FN='#039#039') then'#013#010+
|
|
|
+ ' begin'#013#010+
|
|
|
+ ' FN:=GetAppConfigFile(False);'#013#010+
|
|
|
+ ' If Not F','ileExists(FN) then'#013#010+
|
|
|
+ ' FN:='#039#039';'#013#010+
|
|
|
+ ' end;'#013#010+
|
|
|
+ ' // Global config file fpmake.cfg'#013#010+
|
|
|
+ ' If (FN='#039#039') then'#013#010+
|
|
|
+ ' begin'#013#010+
|
|
|
+ ' FN:=GetAppConfigFile(True);'#013#010+
|
|
|
+ ' If Not FileExists(FN) then'#013#010+
|
|
|
+ ' FN:='#039#039';'#013#010+
|
|
|
+ ' end;'#013#010+
|
|
|
+ ' end;'#013#010+
|
|
|
+ ' If (FN<>'#039,#039') and FileExists(FN) then'#013#010+
|
|
|
+ ' LoadFromFile(FN);'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ #013#010+
|
|
|
+ 'procedure TCustomDefaults.CompilerDefaults;'#013#010+
|
|
|
+ '{$ifdef HAS_UNIT_PROCESS}'#013#010+
|
|
|
+ 'var'#013#010+
|
|
|
+ ' infoSL : TStringList;'#013#010+
|
|
|
+ '{$endif HAS_UNIT_PROCESS}'#013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' if (CPU=cpuNone) or (OS=osNone) or (FComp','ilerVersion='#039#039') the'+
|
|
|
+ 'n'#013#010+
|
|
|
+ ' begin'#013#010+
|
|
|
+ '{$ifdef HAS_UNIT_PROCESS}'#013#010+
|
|
|
+ ' // Detect compiler version/target from -i option'#013#010+
|
|
|
+ ' infosl:=TStringList.Create;'#013#010+
|
|
|
+ ' infosl.Delimiter:='#039' '#039';'#013#010+
|
|
|
+ ' infosl.DelimitedText:=GetCompilerInfo(GetCompiler,'#039'-i','VTPTO'+
|
|
|
+ #039');'#013#010+
|
|
|
+ ' if infosl.Count<>3 then'#013#010+
|
|
|
+ ' Raise EInstallerError.Create(SErrInvalidFPCInfo);'#013#010+
|
|
|
+ ' if FCompilerVersion='#039#039' then'#013#010+
|
|
|
+ ' FCompilerVersion:=infosl[0];'#013#010+
|
|
|
+ ' if CPU=cpuNone then'#013#010+
|
|
|
+ ' CPU:=StringToCPU(infosl[1]);'#013#010+
|
|
|
+ ' ',' if OS=osNone then'#013#010+
|
|
|
+ ' OS:=StringToOS(infosl[2]);'#013#010+
|
|
|
+ '{$else HAS_UNIT_PROCESS}'#013#010+
|
|
|
+ ' // Defaults taken from compiler used to build fpmake'#013#010+
|
|
|
+ ' if CPU=cpuNone then'#013#010+
|
|
|
+ ' CPU:=StringToCPU({$I %FPCTARGETCPU%});'#013#010+
|
|
|
+ ' if OS=osNone t','hen'#013#010+
|
|
|
+ ' OS:=StringToOS({$I %FPCTARGETOS%});'#013#010+
|
|
|
+ ' if FCompilerVersion='#039#039' then'#013#010+
|
|
|
+ ' FCompilerVersion:={$I %FPCVERSION%};'#013#010+
|
|
|
+ '{$endif HAS_UNIT_PROCESS}'#013#010+
|
|
|
+ ' end;'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ #013#010+
|
|
|
+ 'procedure TCustomDefaults.LoadFromFile(Const AFileName: String',');'#013+
|
|
|
+ #010+
|
|
|
+ 'Var'#013#010+
|
|
|
+ ' F : TFileStream;'#013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' F:=TFileStream.Create(AFileName,fmOpenRead);'#013#010+
|
|
|
+ ' Try'#013#010+
|
|
|
+ ' LoadFromStream(F);'#013#010+
|
|
|
+ ' Finally'#013#010+
|
|
|
+ ' F.Free;'#013#010+
|
|
|
+ ' end;'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ #013#010+
|
|
|
+ 'procedure TCustomDefaults.SaveToFile(Const AFileName: String);'#013#010+
|
|
|
+ 'Var'#013#010+
|
|
|
+ ' F : TFileStr','eam;'#013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' F:=TFileStream.Create(AFileName,fmCreate);'#013#010+
|
|
|
+ ' Try'#013#010+
|
|
|
+ ' SaveToStream(F);'#013#010+
|
|
|
+ ' Finally'#013#010+
|
|
|
+ ' F.Free;'#013#010+
|
|
|
+ ' end;'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ #013#010+
|
|
|
+ 'procedure TCustomDefaults.SaveToStream(S : TStream);'#013#010+
|
|
|
+ 'Var'#013#010+
|
|
|
+ ' L : TStringList;'#013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' L:=TStringList.Create;',#013#010+
|
|
|
+ ' try'#013#010+
|
|
|
+ ' With L do'#013#010+
|
|
|
+ ' begin'#013#010+
|
|
|
+ ' Values[KeyArchive]:=FArchive;'#013#010+
|
|
|
+ ' Values[KeyCompiler]:=FCompiler;'#013#010+
|
|
|
+ ' Values[KeyCopy]:=FCopy;'#013#010+
|
|
|
+ ' Values[KeyMkDir]:=FMkDir;'#013#010+
|
|
|
+ ' Values[KeyMove]:=FMove;'#013#010+
|
|
|
+ ' Values[KeyOptions]:=CmdLin','eOptions;'#013#010+
|
|
|
+ ' Values[KeyCPU]:=CPUToString(FCPU);'#013#010+
|
|
|
+ ' Values[KeyOS]:=OSToString(FOS);'#013#010+
|
|
|
+ ' Values[KeyMode]:=ModeToString(FMode);'#013#010+
|
|
|
+ ' Values[KeyLocalUnitDir]:=FLocalUnitDir;'#013#010+
|
|
|
+ ' Values[KeyGlobalUnitDir]:=FGlobalUnitDir;'#013#010+
|
|
|
+ ' V','alues[KeyPrefix]:=FPrefix;'#013#010+
|
|
|
+ ' Values[KeyBaseInstallDir]:=FBaseInstallDir;'#013#010+
|
|
|
+ ' Values[KeyUnitInstallDir]:=FUnitInstallDir;'#013#010+
|
|
|
+ ' Values[KeyBinInstallDir]:=FBinInstallDir;'#013#010+
|
|
|
+ ' Values[KeyDocInstallDir]:=FDocInstallDir;'#013#010+
|
|
|
+ ' Values','[KeyExamplesInstallDir]:=FExamplesInstallDir;'#013#010+
|
|
|
+ ' Values[KeyRemove]:=FRemove;'#013#010+
|
|
|
+ ' Values[KeyRemoveDir]:=FRemoveDir;'#013#010+
|
|
|
+ ' Values[KeyRemoveTree]:=FRemoveTree;'#013#010+
|
|
|
+ ' Values[KeyTarget]:=FTarget;'#013#010+
|
|
|
+ ' if FNoFPCCfg then'#013#010+
|
|
|
+ ' Values','[KeyNoFPCCfg]:='#039'Y'#039';'#013#010+
|
|
|
+ ' if FUseEnvironment then'#013#010+
|
|
|
+ ' Values[KeyUseEnv]:='#039'Y'#039';'#013#010+
|
|
|
+ ' if FInstallExamples then'#013#010+
|
|
|
+ ' Values[KeyInstallExamples]:='#039'Y'#039';'#013#010+
|
|
|
+ ' if FSkipCrossPrograms then'#013#010+
|
|
|
+ ' Values[KeySkipCrossProdrams]:='#039'Y'#039';'#013#010+
|
|
|
+ ' ',' end;'#013#010+
|
|
|
+ ' L.SaveToStream(S);'#013#010+
|
|
|
+ ' Finally'#013#010+
|
|
|
+ ' L.Free;'#013#010+
|
|
|
+ ' end;'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ #013#010+
|
|
|
+ 'procedure TCustomDefaults.LoadFromStream(S: TStream);'#013#010+
|
|
|
+ 'Var'#013#010+
|
|
|
+ ' L : TStrings;'#013#010+
|
|
|
+ ' Line : String;'#013#010+
|
|
|
+ ' I,P,PC : Integer;'#013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' L:=TStringList.Create;'#013#010+
|
|
|
+ ' Try'#013#010+
|
|
|
+ ' L.L','oadFromStream(S);'#013#010+
|
|
|
+ ' // Fix lines.'#013#010+
|
|
|
+ ' For I:=L.Count-1 downto 0 do'#013#010+
|
|
|
+ ' begin'#013#010+
|
|
|
+ ' Line:=L[I];'#013#010+
|
|
|
+ ' P:=Pos('#039'='#039',Line);'#013#010+
|
|
|
+ ' PC:=Pos('#039';'#039',Line); // Comment line.'#013#010+
|
|
|
+ ' If (P=0) or ((PC<>0) and (PC<P)) then'#013#010+
|
|
|
+ ' L.Delete(I)'#013#010+
|
|
|
+ ' ',' else'#013#010+
|
|
|
' L[i]:=Trim(System.Copy(Line,1,P-1)+'#039'='#039'+Trim(System.Cop'+
|
|
|
- 'y(Line,P+1,Length(Line)-P)));'#010+
|
|
|
- ' end;'#010+
|
|
|
- ' With L do'#010+
|
|
|
- ' begin'#010+
|
|
|
- ' FArchive:=Values[KeyArchive];'#010+
|
|
|
- ' FCompiler:=Values[KeyCompiler];'#010+
|
|
|
- ' FCopy:=Values[K','eyCopy];'#010+
|
|
|
- ' FMkDir:=Values[KeyMkDir];'#010+
|
|
|
- ' FMove:=Values[KeyMove];'#010+
|
|
|
- ' FRemove:=Values[KeyRemove];'#010+
|
|
|
- ' FRemoveDir:=Values[KeyRemoveDir];'#010+
|
|
|
- ' FRemoveTree:=Values[KeyRemoveTree];'#010+
|
|
|
- ' Options:=OptionsToStringList(Values[KeyOptions]',');'#010+
|
|
|
- ' Line:=Values[KeyCPU];'#010+
|
|
|
- ' If (Line<>'#039#039') then'#010+
|
|
|
- ' FCPU:=StringToCPU(Line);'#010+
|
|
|
- ' Line:=Values[KeyOS];'#010+
|
|
|
- ' If (Line<>'#039#039') then'#010+
|
|
|
- ' FOS:=StringToOS(Line);'#010+
|
|
|
- ' Line:=Values[KeyMode];'#010+
|
|
|
- ' If (Line<>'#039#039') then'#010+
|
|
|
- ' FMode:','=StringToMode(Line);'#010+
|
|
|
- ' FTarget:=Values[KeyTarget];'#010+
|
|
|
- ' FLocalUnitDir:=Values[KeyLocalUnitDir];'#010+
|
|
|
- ' FGlobalUnitDir:=Values[KeyGlobalUnitDir];'#010+
|
|
|
- ' FPrefix:=Values[KeyPrefix];'#010+
|
|
|
- ' FBaseInstallDir:=Values[KeyBaseInstallDir];'#010+
|
|
|
- ' F','UnitInstallDir:=Values[KeyUnitInstallDir];'#010+
|
|
|
- ' FBinInstallDir:=Values[KeyBinInstallDir];'#010+
|
|
|
- ' FDocInstallDir:=Values[KeyDocInstallDir];'#010+
|
|
|
- ' FExamplesInstallDir:=Values[KeyExamplesInstallDir];'#010+
|
|
|
- ' FInstallExamples:=(Upcase(Values[KeyI','nstallExamples])='#039'Y'#039+
|
|
|
- ');'#010+
|
|
|
+ 'y(Line,P+1,Length(Line)-P)));'#013#010+
|
|
|
+ ' end;'#013#010+
|
|
|
+ ' With L do'#013#010+
|
|
|
+ ' begin'#013#010+
|
|
|
+ ' FArchive:=Values[KeyArchive];'#013#010+
|
|
|
+ ' FCompiler:=Values[KeyCompiler];'#013#010+
|
|
|
+ ' FCopy:=Values[','KeyCopy];'#013#010+
|
|
|
+ ' FMkDir:=Values[KeyMkDir];'#013#010+
|
|
|
+ ' FMove:=Values[KeyMove];'#013#010+
|
|
|
+ ' FRemove:=Values[KeyRemove];'#013#010+
|
|
|
+ ' FRemoveDir:=Values[KeyRemoveDir];'#013#010+
|
|
|
+ ' FRemoveTree:=Values[KeyRemoveTree];'#013#010+
|
|
|
+ ' Options:=OptionsToStringList(Values[KeyO','ptions]);'#013#010+
|
|
|
+ ' Line:=Values[KeyCPU];'#013#010+
|
|
|
+ ' If (Line<>'#039#039') then'#013#010+
|
|
|
+ ' FCPU:=StringToCPU(Line);'#013#010+
|
|
|
+ ' Line:=Values[KeyOS];'#013#010+
|
|
|
+ ' If (Line<>'#039#039') then'#013#010+
|
|
|
+ ' FOS:=StringToOS(Line);'#013#010+
|
|
|
+ ' Line:=Values[KeyMode];'#013#010+
|
|
|
+ ' If (Line<>'#039#039') then',#013#010+
|
|
|
+ ' FMode:=StringToMode(Line);'#013#010+
|
|
|
+ ' FTarget:=Values[KeyTarget];'#013#010+
|
|
|
+ ' FLocalUnitDir:=Values[KeyLocalUnitDir];'#013#010+
|
|
|
+ ' FGlobalUnitDir:=Values[KeyGlobalUnitDir];'#013#010+
|
|
|
+ ' FPrefix:=Values[KeyPrefix];'#013#010+
|
|
|
+ ' FBaseInstallDir:=Values[KeyBas','eInstallDir];'#013#010+
|
|
|
+ ' FUnitInstallDir:=Values[KeyUnitInstallDir];'#013#010+
|
|
|
+ ' FBinInstallDir:=Values[KeyBinInstallDir];'#013#010+
|
|
|
+ ' FDocInstallDir:=Values[KeyDocInstallDir];'#013#010+
|
|
|
+ ' FExamplesInstallDir:=Values[KeyExamplesInstallDir];'#013#010+
|
|
|
+ ' FInstallExa','mples:=(Upcase(Values[KeyInstallExamples])='#039'Y'#039+
|
|
|
+ ');'#013#010+
|
|
|
' FSkipCrossPrograms:=(Upcase(Values[KeySkipCrossProdrams])='#039'Y'+
|
|
|
- #039');'#010+
|
|
|
- ' FNoFPCCfg:=(Upcase(Values[KeyNoFPCCfg])='#039'Y'#039');'#010+
|
|
|
- ' FUseEnvironment:=(Upcase(Values[KeyUseEnv])='#039'Y'#039');'#010+
|
|
|
- #010+
|
|
|
- ' GlobalDictionary.AddVariable('#039'ta','rget'#039',Target);'#010+
|
|
|
+ #039');'#013#010+
|
|
|
+ ' FNoFPCCfg:=(Upcase(Values[KeyNoFPCCfg])='#039'Y'#039');'#013#010+
|
|
|
+ ' FUseEnvironment:=(Upcase(Values[KeyUseEnv])='#039'Y'#039');'#013#010+
|
|
|
+ #013#010+
|
|
|
+ ' G','lobalDictionary.AddVariable('#039'target'#039',Target);'#013#010+
|
|
|
' GlobalDictionary.AddVariable('#039'baseinstalldir'#039',BaseInstal'+
|
|
|
- 'lDir);'#010+
|
|
|
- ' GlobalDictionary.AddVariable('#039'prefix'#039',Prefix);'#010+
|
|
|
+ 'lDir);'#013#010+
|
|
|
+ ' GlobalDictionary.AddVariable('#039'prefix'#039',Prefix);'#013#010+
|
|
|
' GlobalDictionary.AddVariable('#039'bininstalldir'#039',BinInstallD'+
|
|
|
- 'ir);'#010+
|
|
|
- ' end;'#010+
|
|
|
- ' Finally'#010+
|
|
|
- ' L.Free;'#010+
|
|
|
- ' e','nd;'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
- #010+
|
|
|
+ 'ir);'#013#010+
|
|
|
+ ' ',' end;'#013#010+
|
|
|
+ ' Finally'#013#010+
|
|
|
+ ' L.Free;'#013#010+
|
|
|
+ ' end;'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ #013#010+
|
|
|
'{*********************************************************************'+
|
|
|
- '*******'#010+
|
|
|
- ' TFPCDefaults'#010+
|
|
|
- '**********************************************************************'+
|
|
|
- '******}'#010+
|
|
|
- #010+
|
|
|
- 'procedure TFPCDefaults.Compile','rDefaults;'#010+
|
|
|
- 'var'#010+
|
|
|
- ' BD : String;'#010+
|
|
|
- 'begin'#010+
|
|
|
- ' inherited CompilerDefaults;'#010+
|
|
|
- #010+
|
|
|
- ' // Use the same algorithm as the compiler, see options.pas'#010+
|
|
|
- '{$ifdef Unix}'#010+
|
|
|
- ' BD:=FixPath(GetEnvironmentVariable('#039'FPCDIR'#039'), True);'#010+
|
|
|
- ' if BD='#039#039' then'#010+
|
|
|
- ' begin'#010+
|
|
|
- ' BD:='#039'/usr/l','ocal/lib/fpc/'#039'+FCompilerVersion;'#010+
|
|
|
- ' if not DirectoryExists(BD) and'#010+
|
|
|
+ '*******'#013#010+
|
|
|
+ ' TFPCDefaults'#013#010+
|
|
|
+ '*****************************************************************','***'+
|
|
|
+ '********}'#013#010+
|
|
|
+ #013#010+
|
|
|
+ 'procedure TFPCDefaults.CompilerDefaults;'#013#010+
|
|
|
+ 'var'#013#010+
|
|
|
+ ' BD : String;'#013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' inherited CompilerDefaults;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ ' // Use the same algorithm as the compiler, see options.pas'#013#010+
|
|
|
+ '{$ifdef Unix}'#013#010+
|
|
|
+ ' BD:=FixPath(GetEnvironmentVariable('#039'FPCDIR',#039'), False);'#013#010+
|
|
|
+ ' if BD='#039#039' then'#013#010+
|
|
|
+ ' begin'#013#010+
|
|
|
+ ' BD:='#039'/usr/local/lib/fpc/'#039'+FCompilerVersion;'#013#010+
|
|
|
+ ' if not DirectoryExists(BD) and'#013#010+
|
|
|
' DirectoryExists('#039'/usr/lib/fpc/'#039'+FCompilerVersion) the'+
|
|
|
- 'n'#010+
|
|
|
- ' BD:='#039'/usr/lib/fpc/'#039'+FCompilerVersion;'#010+
|
|
|
- ' end;'#010+
|
|
|
- '{$else unix}'#010+
|
|
|
- ' BD:=FixPath(GetEnvironmentVariable('#039,'FPCDIR'#039'), True);'#010+
|
|
|
- ' if BD='#039#039' then'#010+
|
|
|
- ' begin'#010+
|
|
|
- ' BD:=ExtractFilePath(FCompiler)+'#039'..'#039';'#010+
|
|
|
- ' if not(DirectoryExists(BD+'#039'/units'#039')) and'#010+
|
|
|
- ' not(DirectoryExists(BD+'#039'/rtl'#039')) then'#010+
|
|
|
- ' BD:=FBaseInstallDir+'#039'..'#039';'#010+
|
|
|
- ' end;'#010+
|
|
|
- '{$endif unix}'#010+
|
|
|
- #010+
|
|
|
- ' /','/ Where to install by default'#010+
|
|
|
- ' if (FBaseInstallDir='#039#039') and (FPrefix='#039#039') then'#010+
|
|
|
- ' BaseInstallDir:=BD;'#010+
|
|
|
- #010+
|
|
|
- ' // Where to find the units by default'#010+
|
|
|
- ' if (FGlobalUnitDir='#039#039') then'#010+
|
|
|
+ 'n'#013#010+
|
|
|
+ ' BD:='#039'/usr/lib/fpc/'#039'+FCompilerVersion;',#013#010+
|
|
|
+ ' end;'#013#010+
|
|
|
+ '{$else unix}'#013#010+
|
|
|
+ ' BD:=FixPath(GetEnvironmentVariable('#039'FPCDIR'#039'), False);'#013#010+
|
|
|
+ ' if BD='#039#039' then'#013#010+
|
|
|
+ ' begin'#013#010+
|
|
|
+ ' BD:=ExtractFilePath(FCompiler)+'#039'..'#039';'#013#010+
|
|
|
+ ' if not(DirectoryExists(BD+'#039'/units'#039')) and'#013#010+
|
|
|
+ ' not(DirectoryExists(BD+'#039'/rtl',#039')) then'#013#010+
|
|
|
+ ' BD:=FBaseInstallDir+'#039'..'#039';'#013#010+
|
|
|
+ ' end;'#013#010+
|
|
|
+ '{$endif unix}'#013#010+
|
|
|
+ #013#010+
|
|
|
+ ' // Where to install by default'#013#010+
|
|
|
+ ' if (FBaseInstallDir='#039#039') and (FPrefix='#039#039') then'#013#010+
|
|
|
+ ' BaseInstallDir:=BD;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ ' // Where to find the units by default'#013#010+
|
|
|
+ ' if (FGlobalUnit','Dir='#039#039') then'#013#010+
|
|
|
' GlobalUnitDir:=IncludeTrailingPathDelimiter(BD)+'#039'units'#039'+Pa'+
|
|
|
- 'thDel','im+Target;'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
- #010+
|
|
|
+ 'thDelim+Target;'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ #013#010+
|
|
|
'{*********************************************************************'+
|
|
|
- '*******'#010+
|
|
|
- ' TCustomInstaller'#010+
|
|
|
- '**********************************************************************'+
|
|
|
- '******}'#010+
|
|
|
- #010+
|
|
|
- 'constructor TCustomI','nstaller.Create(AOwner: TComponent);'#010+
|
|
|
- 'begin'#010+
|
|
|
- ' FPackageVariantSettings := TStringList.Create;'#010+
|
|
|
- ' FPackageVariants := TFPList.Create;'#010+
|
|
|
- ' GlobalDictionary:=DictionaryClass.Create(Nil);'#010+
|
|
|
- ' AnalyzeOptions;'#010+
|
|
|
- ' GlobalDictionary.AddVariable('#039'BaseInstall','Dir'#039',Defaults.Bas'+
|
|
|
- 'eInstallDir);'#010+
|
|
|
+ '*******'#013#010+
|
|
|
+ ' TCustomInstaller'#013#010+
|
|
|
+ '************','********************************************************'+
|
|
|
+ '********}'#013#010+
|
|
|
+ #013#010+
|
|
|
+ 'constructor TCustomInstaller.Create(AOwner: TComponent);'#013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' FPackageVariantSettings := TStringList.Create;'#013#010+
|
|
|
+ ' FPackageVariants := TFPList.Create;'#013#010+
|
|
|
+ ' GlobalDictionar','y:=DictionaryClass.Create(Nil);'#013#010+
|
|
|
+ ' AnalyzeOptions;'#013#010+
|
|
|
+ ' GlobalDictionary.AddVariable('#039'BaseInstallDir'#039',Defaults.BaseI'+
|
|
|
+ 'nstallDir);'#013#010+
|
|
|
' GlobalDictionary.AddVariable('#039'bininstalldir'#039',Defaults.BinIns'+
|
|
|
- 'tallDir);'#010+
|
|
|
- ' GlobalDictionary.AddVariable('#039'Target'#039',Defaults.Target);'#010+
|
|
|
- ' GlobalDictionary.AddVariable('#039'BuildString'#039',Defaults.BuildStr'+
|
|
|
- 'ing);'#010+
|
|
|
- ' GlobalDic','tionary.AddVariable('#039'Prefix'#039',Defaults.Prefix);'#010+
|
|
|
- ' CreatePackages;'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
- #010+
|
|
|
- 'destructor TCustomInstaller.Destroy;'#010+
|
|
|
- 'var'#010+
|
|
|
- ' i: integer;'#010+
|
|
|
- 'begin'#010+
|
|
|
- ' FreePackages;'#010+
|
|
|
- ' FreeAndNil(Defaults);'#010+
|
|
|
- ' FreeAndNil(GlobalDictionary);'#010+
|
|
|
- ' FreeAndNil(FPackageVariantSetting','s);'#010+
|
|
|
- ' for i := 0 to FPackageVariants.Count-1 do'#010+
|
|
|
- ' begin'#010+
|
|
|
- ' if TPackageVariants(FPackageVariants.Items[i]).Owner=Self then'#010+
|
|
|
- ' TPackageVariants(FPackageVariants.Items[i]).Free;'#010+
|
|
|
- ' end;'#010+
|
|
|
- ' FreeAndNil(FPackageVariants);'#010+
|
|
|
- ' inherited destro','y;'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
- 'function TCustomInstaller.GetPackages: TPackages;'#010+
|
|
|
- 'begin'#010+
|
|
|
- ' result := FPackages;'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
- 'procedure TCustomInstaller.Log(Level: TVerboseLevel; Const Msg: String'+
|
|
|
- ');'#010+
|
|
|
- 'begin'#010+
|
|
|
- ' If Level in FLogLevels then'#010+
|
|
|
- ' begin'#010+
|
|
|
- ' Writeln(StdOut, Msg);'#010+
|
|
|
- ' ',' Flush(StdOut);'#010+
|
|
|
- ' end;'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
- #010+
|
|
|
- 'procedure TCustomInstaller.CreatePackages;'#010+
|
|
|
- 'begin'#010+
|
|
|
- ' FPackages:=TPackages.Create(TPackage);'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
- 'procedure TCustomInstaller.FreePackages;'#010+
|
|
|
- 'begin'#010+
|
|
|
- ' FreeAndNil(FPackages);'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
- #010+
|
|
|
- 'procedure TCustomInstaller.Crea','teBuildEngine;'#010+
|
|
|
- 'begin'#010+
|
|
|
- ' FBuildEngine:=TBuildEngine.Create(Self);'#010+
|
|
|
- '// FBuildEngine.Defaults:=Defaults;'#010+
|
|
|
- ' FBuildEngine.ListMode:=FListMode;'#010+
|
|
|
- ' FBuildEngine.Verbose := (FLogLevels = AllMessages);'#010+
|
|
|
- ' FBuildEngine.OnLog:[email protected];'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
- #010+
|
|
|
- 'procedure',' TCustomInstaller.Error(const Msg: String);'#010+
|
|
|
- 'begin'#010+
|
|
|
- ' Raise EInstallerError.Create(Msg);'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
+ 'tallDir);'#013#010+
|
|
|
+ ' GlobalDictionary.AddVariable('#039'Target'#039',','Defaults.Target);'#013+
|
|
|
#010+
|
|
|
+ ' GlobalDictionary.AddVariable('#039'BuildString'#039',Defaults.BuildStr'+
|
|
|
+ 'ing);'#013#010+
|
|
|
+ ' GlobalDictionary.AddVariable('#039'Prefix'#039',Defaults.Prefix);'#013#010+
|
|
|
+ ' CreatePackages;'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ #013#010+
|
|
|
+ 'destructor TCustomInstaller.Destroy;'#013#010+
|
|
|
+ 'var'#013#010+
|
|
|
+ ' i: integer;'#013#010+
|
|
|
+ 'begin'#013,#010+
|
|
|
+ ' FreePackages;'#013#010+
|
|
|
+ ' FreeAndNil(Defaults);'#013#010+
|
|
|
+ ' FreeAndNil(GlobalDictionary);'#013#010+
|
|
|
+ ' FreeAndNil(FPackageVariantSettings);'#013#010+
|
|
|
+ ' for i := 0 to FPackageVariants.Count-1 do'#013#010+
|
|
|
+ ' begin'#013#010+
|
|
|
+ ' if TPackageVariants(FPackageVariants.Items[i]).Owner=Self then'#013+
|
|
|
+ #010,
|
|
|
+ ' TPackageVariants(FPackageVariants.Items[i]).Free;'#013#010+
|
|
|
+ ' end;'#013#010+
|
|
|
+ ' FreeAndNil(FPackageVariants);'#013#010+
|
|
|
+ ' inherited destroy;'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ 'function TCustomInstaller.GetPackages: TPackages;'#013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' result := FPackages;'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ 'procedure TCustomIns','taller.Log(Level: TVerboseLevel; Const Msg: Stri'+
|
|
|
+ 'ng);'#013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' If Level in FLogLevels then'#013#010+
|
|
|
+ ' begin'#013#010+
|
|
|
+ ' Writeln(StdOut, Msg);'#013#010+
|
|
|
+ ' Flush(StdOut);'#013#010+
|
|
|
+ ' end;'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ #013#010+
|
|
|
+ 'procedure TCustomInstaller.CreatePackages;'#013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' FPackages:=TPacka','ges.Create(TPackage);'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ 'procedure TCustomInstaller.FreePackages;'#013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' FreeAndNil(FPackages);'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ #013#010+
|
|
|
+ 'procedure TCustomInstaller.CreateBuildEngine;'#013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' FBuildEngine:=TBuildEngine.Create(Self);'#013#010+
|
|
|
+ '// FBuildEngine.Defaults:','=Defaults;'#013#010+
|
|
|
+ ' FBuildEngine.ListMode:=FListMode;'#013#010+
|
|
|
+ ' FBuildEngine.Verbose := (FLogLevels = AllMessages);'#013#010+
|
|
|
+ ' FBuildEngine.OnLog:[email protected];'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ #013#010+
|
|
|
+ 'procedure TCustomInstaller.Error(const Msg: String);'#013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' Raise EInstallerError.Create(','Msg);'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ #013#010+
|
|
|
'procedure TCustomInstaller.Error(const Fmt: String; Args: array of con'+
|
|
|
- 'st);'#010+
|
|
|
- 'begin'#010+
|
|
|
- ' Raise EInstallerError.CreateFmt(Fmt,Args);'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
- #010+
|
|
|
- 'Function TCus','tomInstaller.AddPackage(const AName: String) : TPackage'+
|
|
|
- ';'#010+
|
|
|
- 'begin'#010+
|
|
|
- ' result:=Packages.AddPackage(AName);'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
+ 'st);'#013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' Raise EInstallerError.CreateFmt(Fmt,Args);'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ #013#010+
|
|
|
+ 'Function TCustomInstaller.AddPackage(const AName: String) : TPackage;'#013+
|
|
|
+ #010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' resu','lt:=Packages.AddPackage(AName);'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
'function TCustomInstaller.AddPackageVariant(AName: string; AIsInherita'+
|
|
|
- 'ble: boolean): TPackageVariants;'#010+
|
|
|
- 'begin'#010+
|
|
|
- ' result := TPackageVari','ants.Create(TPackageVariant);'#010+
|
|
|
- ' result.Name:=AName;'#010+
|
|
|
- ' result.FIsInheritable:=AIsInheritable;'#010+
|
|
|
- ' FPackageVariants.Add(result);'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
- 'procedure TCustomInstaller.AnalyzeOptions;'#010+
|
|
|
- #010+
|
|
|
- ' Function CheckOption(Index : Integer;const Short,Long : String;',' Ad'+
|
|
|
- 'dToOptionString: boolean = true): Boolean;'#010+
|
|
|
- ' var'#010+
|
|
|
- ' O : String;'#010+
|
|
|
- ' begin'#010+
|
|
|
- ' O:=Paramstr(Index);'#010+
|
|
|
+ 'ble: boolean): TPackageVariants;'#013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' result := TPackageVariants.Create(TPackageVariant);'#013#010+
|
|
|
+ ' result.Name:=AName;'#013#010+
|
|
|
+ ' result.F','IsInheritable:=AIsInheritable;'#013#010+
|
|
|
+ ' FPackageVariants.Add(result);'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ 'procedure TCustomInstaller.AnalyzeOptions;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ ' Function CheckOption(Index : Integer;const Short,Long : String; AddT'+
|
|
|
+ 'oOptionString: boolean = true): Boolean;'#013#010+
|
|
|
+ ' var'#013#010+
|
|
|
+ ' ',' O : String;'#013#010+
|
|
|
+ ' begin'#013#010+
|
|
|
+ ' O:=Paramstr(Index);'#013#010+
|
|
|
' Result:=(O='#039'-'#039'+short) or (O='#039'--'#039'+long) or (copy(O,'+
|
|
|
- '1,Length(Long)+3)=('#039'--'#039'+long+'#039'='#039'));'#010+
|
|
|
- ' if AddToOptionString and Result then FFPMakeOp','tionsString := FFP'+
|
|
|
- 'MakeOptionsString+'#039' '#039'+O;'#010+
|
|
|
- ' end;'#010+
|
|
|
- #010+
|
|
|
- ' Function CheckBuildOptionSetValue(Index: Integer): boolean;'#010+
|
|
|
- ' var'#010+
|
|
|
- ' O : String;'#010+
|
|
|
- ' BuildModeName: string;'#010+
|
|
|
- ' P: integer;'#010+
|
|
|
- ' begin'#010+
|
|
|
- ' O:=Paramstr(Index);'#010+
|
|
|
- ' result := O[1]='#039'+'#039';'#010+
|
|
|
- ' if',' result then'#010+
|
|
|
- ' begin'#010+
|
|
|
- ' P:=Pos('#039'='#039',Paramstr(Index));'#010+
|
|
|
- ' If (P=0) then'#010+
|
|
|
- ' Error(SErrNeedArgument,[Index,O])'#010+
|
|
|
- ' else'#010+
|
|
|
- ' begin'#010+
|
|
|
- ' BuildModeName:=copy(o,2,P-2);'#010+
|
|
|
- ' Delete(O,1,P);'#010+
|
|
|
- ' FPackageVariantSettings.','Values[BuildModeName] := O;'#010+
|
|
|
- ' end;'#010+
|
|
|
- ' end;'#010+
|
|
|
- ' end;'#010+
|
|
|
- #010+
|
|
|
+ '1,Length(Long)+3)=('#039'--'#039'+long+'#039'='#039'));'#013#010+
|
|
|
+ ' if AddToOptionString and Result then FFPMakeOptionsString := FFPMa'+
|
|
|
+ 'keOptionsString+'#039' '#039'+O;'#013#010+
|
|
|
+ ' end;',#013#010+
|
|
|
+ #013#010+
|
|
|
+ ' Function CheckBuildOptionSetValue(Index: Integer): boolean;'#013#010+
|
|
|
+ ' var'#013#010+
|
|
|
+ ' O : String;'#013#010+
|
|
|
+ ' BuildModeName: string;'#013#010+
|
|
|
+ ' P: integer;'#013#010+
|
|
|
+ ' begin'#013#010+
|
|
|
+ ' O:=Paramstr(Index);'#013#010+
|
|
|
+ ' result := O[1]='#039'+'#039';'#013#010+
|
|
|
+ ' if result then'#013#010+
|
|
|
+ ' begin'#013#010+
|
|
|
+ ' P:=Pos','('#039'='#039',Paramstr(Index));'#013#010+
|
|
|
+ ' If (P=0) then'#013#010+
|
|
|
+ ' Error(SErrNeedArgument,[Index,O])'#013#010+
|
|
|
+ ' else'#013#010+
|
|
|
+ ' begin'#013#010+
|
|
|
+ ' BuildModeName:=copy(o,2,P-2);'#013#010+
|
|
|
+ ' Delete(O,1,P);'#013#010+
|
|
|
+ ' FPackageVariantSettings.Values[BuildModeName] := O;'#013#010+
|
|
|
+ ' ',' end;'#013#010+
|
|
|
+ ' end;'#013#010+
|
|
|
+ ' end;'#013#010+
|
|
|
+ #013#010+
|
|
|
' Function CheckCustomOption(Index : Integer; out CustOptName: string)'+
|
|
|
- ': Boolean;'#010+
|
|
|
- ' var'#010+
|
|
|
- ' O : String;'#010+
|
|
|
- ' i : integer;'#010+
|
|
|
- ' begin'#010+
|
|
|
- ' result := false;'#010+
|
|
|
- ' CustOptName:='#039#039';'#010+
|
|
|
- ' O:=Par','amstr(Index);'#010+
|
|
|
- ' if copy(O,1,2)<>'#039'--'#039' then'#010+
|
|
|
- ' Exit;'#010+
|
|
|
- ' i := pos('#039'='#039',O);'#010+
|
|
|
- ' if i=0 then'#010+
|
|
|
- ' Exit;'#010+
|
|
|
- ' O:=copy(O,3,i-3);'#010+
|
|
|
- ' CustOptName:=O;'#010+
|
|
|
- ' Result:=CustomFpmakeCommandlineOptions.IndexOfName(O)>-1;'#010+
|
|
|
- ' if Result then FFPMakeOptio','nsString := FFPMakeOptionsString+'#039+
|
|
|
- ' '#039'+Paramstr(Index);'#010+
|
|
|
- ' end;'#010+
|
|
|
- #010+
|
|
|
- #010+
|
|
|
+ ': Boolean;'#013#010+
|
|
|
+ ' var'#013#010+
|
|
|
+ ' O : String;'#013#010+
|
|
|
+ ' i : integer;'#013#010+
|
|
|
+ ' begin'#013#010+
|
|
|
+ ' result := false;'#013#010+
|
|
|
+ ' CustOptName:='#039#039';'#013#010+
|
|
|
+ ' O:=Paramstr(Index);'#013#010+
|
|
|
+ ' ',' if copy(O,1,2)<>'#039'--'#039' then'#013#010+
|
|
|
+ ' Exit;'#013#010+
|
|
|
+ ' i := pos('#039'='#039',O);'#013#010+
|
|
|
+ ' if i=0 then'#013#010+
|
|
|
+ ' Exit;'#013#010+
|
|
|
+ ' O:=copy(O,3,i-3);'#013#010+
|
|
|
+ ' CustOptName:=O;'#013#010+
|
|
|
+ ' Result:=CustomFpmakeCommandlineOptions.IndexOfName(O)>-1;'#013#010+
|
|
|
+ ' if Result then FFPMakeOptionsString ',':= FFPMakeOptionsString+'#039+
|
|
|
+ ' '#039'+Paramstr(Index);'#013#010+
|
|
|
+ ' end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ #013#010+
|
|
|
' Function CheckCommand(Index : Integer;const Short,Long : String): Bo'+
|
|
|
- 'olean;'#010+
|
|
|
- ' var'#010+
|
|
|
- ' O : String;'#010+
|
|
|
- ' begin'#010+
|
|
|
- ' O:=Paramstr(Index);'#010+
|
|
|
- ' Result:=(O='#039'-'#039'+short) or (O=long);'#010+
|
|
|
- ' end;'#010,
|
|
|
- #010+
|
|
|
- ' Function OptionArg(Var Index : Integer) : String;'#010+
|
|
|
- ' Var'#010+
|
|
|
- ' P : Integer;'#010+
|
|
|
- ' begin'#010+
|
|
|
+ 'olean;'#013#010+
|
|
|
+ ' var'#013#010+
|
|
|
+ ' O : String;'#013#010+
|
|
|
+ ' begin'#013#010+
|
|
|
+ ' O:=Paramstr(Index);'#013#010+
|
|
|
+ ' Result:=(O='#039'-'#039'+short) or (O=long);'#013#010+
|
|
|
+ ' end;',#013#010+
|
|
|
+ #013#010+
|
|
|
+ ' Function OptionArg(Var Index : Integer) : String;'#013#010+
|
|
|
+ ' Var'#013#010+
|
|
|
+ ' P : Integer;'#013#010+
|
|
|
+ ' begin'#013#010+
|
|
|
' if (Length(ParamStr(Index))>1) and (Paramstr(Index)[2]<>'#039'-'#039+
|
|
|
- ') then'#010+
|
|
|
- ' begin'#010+
|
|
|
- ' If Index<ParamCount then'#010+
|
|
|
- ' begin'#010+
|
|
|
- ' Inc(Index);'#010+
|
|
|
- ' R','esult:=Paramstr(Index);'#010+
|
|
|
- ' end'#010+
|
|
|
- ' else'#010+
|
|
|
- ' Error(SErrNeedArgument,[Index,ParamStr(Index)]);'#010+
|
|
|
- ' end'#010+
|
|
|
- ' else If length(ParamStr(Index))>2 then'#010+
|
|
|
- ' begin'#010+
|
|
|
- ' P:=Pos('#039'='#039',Paramstr(Index));'#010+
|
|
|
- ' If (P=0) then'#010+
|
|
|
- ' Error(SE','rrNeedArgument,[Index,ParamStr(Index)])'#010+
|
|
|
- ' else'#010+
|
|
|
- ' begin'#010+
|
|
|
- ' Result:=Paramstr(Index);'#010+
|
|
|
- ' Delete(Result,1,P);'#010+
|
|
|
- ' end;'#010+
|
|
|
- ' end;'#010+
|
|
|
- ' end;'#010+
|
|
|
- #010+
|
|
|
- ' function SplitSpaces(var SplitString: string) : string;'#010+
|
|
|
- ' var i : integer;'#010+
|
|
|
- ' beg','in'#010+
|
|
|
- ' i := pos('#039' '#039',SplitString);'#010+
|
|
|
- ' if i > 0 then'#010+
|
|
|
- ' begin'#010+
|
|
|
- ' result := copy(SplitString,1,i-1);'#010+
|
|
|
- ' delete(SplitString,1,i);'#010+
|
|
|
- ' end'#010+
|
|
|
- ' else'#010+
|
|
|
- ' begin'#010+
|
|
|
- ' result := SplitString;'#010+
|
|
|
- ' SplitString:='#039#039';'#010+
|
|
|
- ' end;'#010+
|
|
|
- ' ','end;'#010+
|
|
|
- #010+
|
|
|
- 'Var'#010+
|
|
|
- ' I : Integer;'#010+
|
|
|
- ' DefaultsFileName : string;'#010+
|
|
|
- ' OptString : string;'#010+
|
|
|
- ' CustOptName : string;'#010+
|
|
|
- 'begin'#010+
|
|
|
- ' I:=0;'#010+
|
|
|
- ' FListMode:=False;'#010+
|
|
|
- ' FLogLevels:=DefaultMessages;'#010+
|
|
|
- ' While (I<ParamCount) do'#010+
|
|
|
- ' begin'#010+
|
|
|
- ' Inc(I);'#010+
|
|
|
- ' if CheckOption(I,'#039'v'#039','#039'v','erbose'#039',false) then'#010+
|
|
|
- ' FLogLevels:=AllMessages'#010+
|
|
|
- ' else if CheckOption(I,'#039'd'#039','#039'debug'#039',false) then'#010+
|
|
|
- ' FLogLevels:=AllMessages+[vlDebug]'#010+
|
|
|
- ' else if CheckCommand(I,'#039'm'#039','#039'compile'#039') then'#010+
|
|
|
- ' FRunMode:=rmCompile'#010+
|
|
|
- ' else if CheckCommand(I,',#039'b'#039','#039'build'#039') then'#010+
|
|
|
- ' FRunMode:=rmBuild'#010+
|
|
|
- ' else if CheckCommand(I,'#039'i'#039','#039'install'#039') then'#010+
|
|
|
- ' FRunMode:=rmInstall'#010+
|
|
|
- ' else if CheckCommand(I,'#039'zi'#039','#039'zipinstall'#039') then'#010+
|
|
|
- ' FRunMode:=rmZipInstall'#010+
|
|
|
- ' else if CheckCommand(I,'#039'c'#039','#039'clean'#039') then'#010,
|
|
|
- ' FRunMode:=rmClean'#010+
|
|
|
- ' else if CheckCommand(I,'#039'dc'#039','#039'distclean'#039') then'#010+
|
|
|
- ' FRunMode:=rmDistClean'#010+
|
|
|
- ' else if CheckCommand(I,'#039'a'#039','#039'archive'#039') then'#010+
|
|
|
- ' FRunMode:=rmarchive'#010+
|
|
|
- ' else if CheckCommand(I,'#039'M'#039','#039'manifest'#039') then'#010+
|
|
|
- ' FRunMode:=r','mManifest'#010+
|
|
|
- ' else if CheckOption(I,'#039'h'#039','#039'help'#039') then'#010+
|
|
|
- ' Usage('#039#039',[])'#010+
|
|
|
- ' else if Checkoption(I,'#039'C'#039','#039'cpu'#039') then'#010+
|
|
|
- ' Defaults.CPU:=StringToCPU(OptionArg(I))'#010+
|
|
|
- ' else if Checkoption(I,'#039'O'#039','#039'os'#039') then'#010+
|
|
|
- ' Defaults.OS:=StringToOS(OptionArg','(I))'#010+
|
|
|
- ' else if Checkoption(I,'#039't'#039','#039'target'#039') then'#010+
|
|
|
- ' Defaults.Target:=OptionArg(I)'#010+
|
|
|
- ' else if CheckOption(I,'#039'l'#039','#039'list-commands'#039') then'#010+
|
|
|
- ' FListMode:=True'#010+
|
|
|
- ' else if Checkoption(I,'#039'P'#039','#039'prefix'#039') then'#010+
|
|
|
- ' Defaults.Prefix:=OptionArg(I)',#010+
|
|
|
- ' else if Checkoption(I,'#039'n'#039','#039'nofpccfg'#039') then'#010+
|
|
|
- ' Defaults.NoFPCCfg:=true'#010+
|
|
|
- '{$ifdef HAS_UNIT_PROCESS}'#010+
|
|
|
- ' else if Checkoption(I,'#039'e'#039','#039'useenv'#039') then'#010+
|
|
|
- ' Defaults.UseEnvironment:=true'#010+
|
|
|
- '{$endif}'#010+
|
|
|
- '{$ifndef NO_THREADING}'#010+
|
|
|
- ' else if CheckOption','(I,'#039'T'#039','#039'threads'#039') then'#010+
|
|
|
- ' Defaults.ThreadsAmount:=StrToIntDef(OptionArg(I),-1)'#010+
|
|
|
- '{$endif NO_THREADING}'#010+
|
|
|
- ' else if CheckOption(I,'#039'B'#039','#039'baseinstalldir'#039') then'#010+
|
|
|
- ' Defaults.BaseInstallDir:=OptionArg(I)'#010+
|
|
|
- ' else if CheckOption(I,'#039'U'#039','#039'unitinst','alldir'#039') then'+
|
|
|
- #010+
|
|
|
- ' Defaults.UnitInstallDir:=OptionArg(I)'#010+
|
|
|
- ' else if CheckOption(I,'#039'UL'#039','#039'localunitdir'#039') then'#010+
|
|
|
- ' Defaults.LocalUnitDir:=OptionArg(I)'#010+
|
|
|
- ' else if CheckOption(I,'#039'UG'#039','#039'globalunitdir'#039') then'#010+
|
|
|
- ' Defaults.GlobalUnitDir:=Optio','nArg(I)'#010+
|
|
|
- ' else if CheckOption(I,'#039'o'#039','#039'options'#039') then'#010+
|
|
|
- ' begin'#010+
|
|
|
- ' OptString := OptionArg(I);'#010+
|
|
|
- ' while OptString <> '#039#039' do'#010+
|
|
|
- ' Defaults.Options.Add(SplitSpaces(OptString));'#010+
|
|
|
- ' end'#010+
|
|
|
- ' else if CheckOption(I,'#039'r'#039','#039'compiler'#039,') then'#010+
|
|
|
- ' Defaults.Compiler:=OptionArg(I)'#010+
|
|
|
- ' else if CheckOption(I,'#039'f'#039','#039'config'#039') then'#010+
|
|
|
- ' DefaultsFileName:=OptionArg(I)'#010+
|
|
|
+ ') then'#013#010+
|
|
|
+ ' begin'#013#010+
|
|
|
+ ' If Index<ParamCount then'#013#010+
|
|
|
+ ' begin'#013#010+
|
|
|
+ ' Inc(Index)',';'#013#010+
|
|
|
+ ' Result:=Paramstr(Index);'#013#010+
|
|
|
+ ' end'#013#010+
|
|
|
+ ' else'#013#010+
|
|
|
+ ' Error(SErrNeedArgument,[Index,ParamStr(Index)]);'#013#010+
|
|
|
+ ' end'#013#010+
|
|
|
+ ' else If length(ParamStr(Index))>2 then'#013#010+
|
|
|
+ ' begin'#013#010+
|
|
|
+ ' P:=Pos('#039'='#039',Paramstr(Index));'#013#010+
|
|
|
+ ' If (P=0) t','hen'#013#010+
|
|
|
+ ' Error(SErrNeedArgument,[Index,ParamStr(Index)])'#013#010+
|
|
|
+ ' else'#013#010+
|
|
|
+ ' begin'#013#010+
|
|
|
+ ' Result:=Paramstr(Index);'#013#010+
|
|
|
+ ' Delete(Result,1,P);'#013#010+
|
|
|
+ ' end;'#013#010+
|
|
|
+ ' end;'#013#010+
|
|
|
+ ' end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ ' function SplitSpaces(var SplitString: string) : st','ring;'#013#010+
|
|
|
+ ' var i : integer;'#013#010+
|
|
|
+ ' begin'#013#010+
|
|
|
+ ' i := pos('#039' '#039',SplitString);'#013#010+
|
|
|
+ ' if i > 0 then'#013#010+
|
|
|
+ ' begin'#013#010+
|
|
|
+ ' result := copy(SplitString,1,i-1);'#013#010+
|
|
|
+ ' delete(SplitString,1,i);'#013#010+
|
|
|
+ ' end'#013#010+
|
|
|
+ ' else'#013#010+
|
|
|
+ ' begin'#013#010+
|
|
|
+ ' result := SplitStrin','g;'#013#010+
|
|
|
+ ' SplitString:='#039#039';'#013#010+
|
|
|
+ ' end;'#013#010+
|
|
|
+ ' end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ 'Var'#013#010+
|
|
|
+ ' I : Integer;'#013#010+
|
|
|
+ ' DefaultsFileName : string;'#013#010+
|
|
|
+ ' OptString : string;'#013#010+
|
|
|
+ ' CustOptName : string;'#013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' I:=0;'#013#010+
|
|
|
+ ' FListMode:=False;'#013#010+
|
|
|
+ ' FLogLevels:=DefaultMessages;'#013#010+
|
|
|
+ ' While (I<ParamCoun','t) do'#013#010+
|
|
|
+ ' begin'#013#010+
|
|
|
+ ' Inc(I);'#013#010+
|
|
|
+ ' if CheckOption(I,'#039'v'#039','#039'verbose'#039',false) then'#013#010+
|
|
|
+ ' FLogLevels:=AllMessages'#013#010+
|
|
|
+ ' else if CheckOption(I,'#039'd'#039','#039'debug'#039',false) then'#013#010+
|
|
|
+ ' FLogLevels:=AllMessages+[vlDebug]'#013#010+
|
|
|
+ ' else if CheckCommand(I,'#039'm'#039','#039'compil','e'#039') then'#013#010+
|
|
|
+ ' FRunMode:=rmCompile'#013#010+
|
|
|
+ ' else if CheckCommand(I,'#039'b'#039','#039'build'#039') then'#013#010+
|
|
|
+ ' FRunMode:=rmBuild'#013#010+
|
|
|
+ ' else if CheckCommand(I,'#039'i'#039','#039'install'#039') then'#013#010+
|
|
|
+ ' FRunMode:=rmInstall'#013#010+
|
|
|
+ ' else if CheckCommand(I,'#039'zi'#039','#039'zipinstall'#039') then'#013+
|
|
|
+ #010+
|
|
|
+ ' ',' FRunMode:=rmZipInstall'#013#010+
|
|
|
+ ' else if CheckCommand(I,'#039'c'#039','#039'clean'#039') then'#013#010+
|
|
|
+ ' FRunMode:=rmClean'#013#010+
|
|
|
+ ' else if CheckCommand(I,'#039'dc'#039','#039'distclean'#039') then'#013#010+
|
|
|
+ ' FRunMode:=rmDistClean'#013#010+
|
|
|
+ ' else if CheckCommand(I,'#039'a'#039','#039'archive'#039') then'#013#010+
|
|
|
+ ' FRunMode:=','rmarchive'#013#010+
|
|
|
+ ' else if CheckCommand(I,'#039'M'#039','#039'manifest'#039') then'#013#010+
|
|
|
+ ' FRunMode:=rmManifest'#013#010+
|
|
|
+ ' else if CheckOption(I,'#039'h'#039','#039'help'#039') then'#013#010+
|
|
|
+ ' Usage('#039#039',[])'#013#010+
|
|
|
+ ' else if Checkoption(I,'#039'C'#039','#039'cpu'#039') then'#013#010+
|
|
|
+ ' Defaults.CPU:=StringToCPU(OptionArg(I))',#013#010+
|
|
|
+ ' else if Checkoption(I,'#039'O'#039','#039'os'#039') then'#013#010+
|
|
|
+ ' Defaults.OS:=StringToOS(OptionArg(I))'#013#010+
|
|
|
+ ' else if Checkoption(I,'#039't'#039','#039'target'#039') then'#013#010+
|
|
|
+ ' Defaults.Target:=OptionArg(I)'#013#010+
|
|
|
+ ' else if CheckOption(I,'#039'l'#039','#039'list-commands'#039') then'#013+
|
|
|
+ #010+
|
|
|
+ ' FListMode',':=True'#013#010+
|
|
|
+ ' else if Checkoption(I,'#039'P'#039','#039'prefix'#039') then'#013#010+
|
|
|
+ ' Defaults.Prefix:=OptionArg(I)'#013#010+
|
|
|
+ ' else if Checkoption(I,'#039'n'#039','#039'nofpccfg'#039') then'#013#010+
|
|
|
+ ' Defaults.NoFPCCfg:=true'#013#010+
|
|
|
+ '{$ifdef HAS_UNIT_PROCESS}'#013#010+
|
|
|
+ ' else if Checkoption(I,'#039'e'#039','#039'useenv'#039') the','n'#013#010+
|
|
|
+ ' Defaults.UseEnvironment:=true'#013#010+
|
|
|
+ '{$endif}'#013#010+
|
|
|
+ '{$ifndef NO_THREADING}'#013#010+
|
|
|
+ ' else if CheckOption(I,'#039'T'#039','#039'threads'#039') then'#013#010+
|
|
|
+ ' Defaults.ThreadsAmount:=StrToIntDef(OptionArg(I),-1)'#013#010+
|
|
|
+ '{$endif NO_THREADING}'#013#010+
|
|
|
+ ' else if CheckOption(I,'#039'B'#039','#039'basei','nstalldir'#039') then'+
|
|
|
+ #013#010+
|
|
|
+ ' Defaults.BaseInstallDir:=OptionArg(I)'#013#010+
|
|
|
+ ' else if CheckOption(I,'#039'U'#039','#039'unitinstalldir'#039') then'#013+
|
|
|
+ #010+
|
|
|
+ ' Defaults.UnitInstallDir:=OptionArg(I)'#013#010+
|
|
|
+ ' else if CheckOption(I,'#039'UL'#039','#039'localunitdir'#039') then'#013+
|
|
|
+ #010+
|
|
|
+ ' Defaults.LocalUnitD','ir:=OptionArg(I)'#013#010+
|
|
|
+ ' else if CheckOption(I,'#039'UG'#039','#039'globalunitdir'#039') then'#013+
|
|
|
+ #010+
|
|
|
+ ' Defaults.GlobalUnitDir:=OptionArg(I)'#013#010+
|
|
|
+ ' else if CheckOption(I,'#039'o'#039','#039'options'#039') then'#013#010+
|
|
|
+ ' begin'#013#010+
|
|
|
+ ' OptString := OptionArg(I);'#013#010+
|
|
|
+ ' while OptString <> '#039,#039' do'#013#010+
|
|
|
+ ' Defaults.Options.Add(SplitSpaces(OptString));'#013#010+
|
|
|
+ ' end'#013#010+
|
|
|
+ ' else if CheckOption(I,'#039'r'#039','#039'compiler'#039') then'#013#010+
|
|
|
+ ' Defaults.Compiler:=OptionArg(I)'#013#010+
|
|
|
+ ' else if CheckOption(I,'#039'f'#039','#039'config'#039') then'#013#010+
|
|
|
+ ' DefaultsFileName:=OptionArg','(I)'#013#010+
|
|
|
' else if CheckOption(I,'#039'ie'#039','#039'installexamples'#039') then'+
|
|
|
- #010+
|
|
|
- ' Defaults.InstallExamples:=true'#010+
|
|
|
- ' else if CheckOpti','on(I,'#039'sp'#039','#039'skipcrossprograms'#039') '+
|
|
|
- 'then'#010+
|
|
|
- ' Defaults.SkipCrossPrograms:=true'#010+
|
|
|
- ' else if CheckOption(I,'#039'bu'#039','#039'buildunit'#039') then'#010+
|
|
|
- ' Defaults.BuildMode:=bmBuildUnit'#010+
|
|
|
+ #013#010+
|
|
|
+ ' Defaults.InstallExamples:=true'#013#010+
|
|
|
+ ' else if CheckOption(I,'#039'sp'#039','#039'skipcrossprograms'#039') th'+
|
|
|
+ 'en'#013#010+
|
|
|
+ ' Defaults.SkipCrossPrograms:=true'#013#010+
|
|
|
+ ' else if CheckOption(I,'#039'bu'#039','#039'buildunit'#039')',' then'#013+
|
|
|
+ #010+
|
|
|
+ ' Defaults.BuildMode:=bmBuildUnit'#013#010+
|
|
|
' else if CheckOption(I,'#039'io'#039','#039'ignoreinvalidoption'#039') '+
|
|
|
- 'then'#010+
|
|
|
- ' Defaults.Igno','reInvalidOptions:=true'#010+
|
|
|
- ' else if CheckOption(I,'#039'd'#039','#039'doc-folder'#039') then'#010+
|
|
|
- ' Defaults.FPDocOutputDir:=OptionArg(I)'#010+
|
|
|
+ 'then'#013#010+
|
|
|
+ ' Defaults.IgnoreInvalidOptions:=true'#013#010+
|
|
|
+ ' else if CheckOption(I,'#039'd'#039','#039'doc-folder'#039') then'#013#010+
|
|
|
+ ' Defaults.FPDocOutputDir:=OptionArg(','I)'#013#010+
|
|
|
' else if assigned(CustomFpmakeCommandlineOptions) and CheckCustomOp'+
|
|
|
- 'tion(I,CustOptName) then'#010+
|
|
|
- ' begin'#010+
|
|
|
- ' if not assi','gned(CustomFpMakeCommandlineValues) then'#010+
|
|
|
- ' CustomFpMakeCommandlineValues := TStringList.Create;'#010+
|
|
|
- ' CustomFpMakeCommandlineValues.Values[CustOptName]:=OptionArg(I)'#010+
|
|
|
- ' end'#010+
|
|
|
- ' else if (not CheckBuildOptionSetValue(I)) and (not Def','aults.Igno'+
|
|
|
- 'reInvalidOptions) then'#010+
|
|
|
- ' begin'#010+
|
|
|
- ' Usage(SErrInValidArgument,[I,ParamStr(I)]);'#010+
|
|
|
- ' end;'#010+
|
|
|
- ' end;'#010+
|
|
|
- ' If DefaultsFileName<>'#039#039' then'#010+
|
|
|
- ' Defaults.LocalInit(DefaultsFileName);'#010+
|
|
|
- ' Defaults.CompilerDefaults;'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
- #010+
|
|
|
- 'procedure TCusto','mInstaller.Usage(const FMT: String; Args: array of c'+
|
|
|
- 'onst);'#010+
|
|
|
- #010+
|
|
|
- ' Procedure LogCmd(const LC,Msg : String);'#010+
|
|
|
- ' begin'#010+
|
|
|
- ' Log(vlInfo,Format('#039' %-12s %s'#039',[LC,MSG]));'#010+
|
|
|
- ' end;'#010+
|
|
|
- #010+
|
|
|
- ' Procedure LogOption(const C,LC,Msg : String);'#010+
|
|
|
- ' begin'#010+
|
|
|
- ' Log(vlInfo,Form','at('#039' -%s --%-16s %s'#039',[C,LC,MSG]));'#010+
|
|
|
- ' end;'#010+
|
|
|
- #010+
|
|
|
- ' Procedure LogArgOption(const C,LC,Msg : String);'#010+
|
|
|
- ' begin'#010+
|
|
|
- ' if trim(c)='#039#039' then'#010+
|
|
|
+ 'tion(I,CustOptName) then'#013#010+
|
|
|
+ ' begin'#013#010+
|
|
|
+ ' if not assigned(CustomFpMakeCommandlineValues) then'#013#010+
|
|
|
+ ' CustomFpMakeCommandlineValues := TStringList.Create;'#013#010+
|
|
|
+ ' ','CustomFpMakeCommandlineValues.Values[CustOptName]:=OptionArg(I'+
|
|
|
+ ')'#013#010+
|
|
|
+ ' end'#013#010+
|
|
|
+ ' else if (not CheckBuildOptionSetValue(I)) and (not Defaults.Ignore'+
|
|
|
+ 'InvalidOptions) then'#013#010+
|
|
|
+ ' begin'#013#010+
|
|
|
+ ' Usage(SErrInValidArgument,[I,ParamStr(I)]);'#013#010+
|
|
|
+ ' en','d;'#013#010+
|
|
|
+ ' end;'#013#010+
|
|
|
+ ' If DefaultsFileName<>'#039#039' then'#013#010+
|
|
|
+ ' Defaults.LocalInit(DefaultsFileName);'#013#010+
|
|
|
+ ' Defaults.CompilerDefaults;'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ #013#010+
|
|
|
+ 'procedure TCustomInstaller.Usage(const FMT: String; Args: array of con'+
|
|
|
+ 'st);'#013#010+
|
|
|
+ #013#010+
|
|
|
+ ' Procedure LogCmd(const LC,Msg :',' String);'#013#010+
|
|
|
+ ' begin'#013#010+
|
|
|
+ ' Log(vlInfo,Format('#039' %-12s %s'#039',[LC,MSG]));'#013#010+
|
|
|
+ ' end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ ' Procedure LogOption(const C,LC,Msg : String);'#013#010+
|
|
|
+ ' begin'#013#010+
|
|
|
+ ' Log(vlInfo,Format('#039' -%s --%-16s %s'#039',[C,LC,MSG]));'#013#010+
|
|
|
+ ' end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ ' Procedure LogArgOption(const C,LC,Msg ',': String);'#013#010+
|
|
|
+ ' begin'#013#010+
|
|
|
+ ' if trim(c)='#039#039' then'#013#010+
|
|
|
' Log(vlInfo,Format('#039' --%-20s %s'#039',[LC+'#039'='#039'+SValu'+
|
|
|
- 'e,MSG]))'#010+
|
|
|
- ' else'#010+
|
|
|
- ' Log(vlInfo,Format('#039' -%s --%-20s %s'#039',[','C,LC+'#039'='#039'+'+
|
|
|
- 'SValue,MSG]));'#010+
|
|
|
- ' end;'#010+
|
|
|
- #010+
|
|
|
- 'var'#010+
|
|
|
- ' i: Integer;'#010+
|
|
|
- 'begin'#010+
|
|
|
- ' // Force the Usage to be displayed'#010+
|
|
|
- ' Include(FLogLevels,vlInfo);'#010+
|
|
|
- ' If (FMT<>'#039#039') then'#010+
|
|
|
- ' Log(vlInfo,Format(Fmt,Args));'#010+
|
|
|
- ' Log(vlInfo,Format(SHelpUsage,[Paramstr(0)]));'#010+
|
|
|
- ' Log(vlInfo,SH','elpCommand);'#010+
|
|
|
- ' LogCmd('#039'compile'#039',SHelpCompile);'#010+
|
|
|
- ' LogCmd('#039'build'#039',SHelpBuild);'#010+
|
|
|
- ' LogCmd('#039'install'#039',SHelpInstall);'#010+
|
|
|
- ' LogCmd('#039'clean'#039',SHelpClean);'#010+
|
|
|
- ' LogCmd('#039'archive'#039',SHelpArchive);'#010+
|
|
|
- ' LogCmd('#039'manifest'#039',SHelpManifest);'#010+
|
|
|
- ' Log(vlInfo,SHelpCmdOptions)',';'#010+
|
|
|
- ' LogOption('#039'h'#039','#039'help'#039',SHelpHelp);'#010+
|
|
|
- ' LogOption('#039'l'#039','#039'list-commands'#039',SHelpList);'#010+
|
|
|
- ' LogOption('#039'n'#039','#039'nofpccfg'#039',SHelpNoFPCCfg);'#010+
|
|
|
- ' LogOption('#039'v'#039','#039'verbose'#039',SHelpVerbose);'#010+
|
|
|
- '{$ifdef HAS_UNIT_PROCESS}'#010+
|
|
|
- ' LogOption('#039'e'#039', '#039'useenv'#039', sHelpUseEnvironment);'#010,
|
|
|
- '{$endif}'#010+
|
|
|
- ' LogOption('#039'ie'#039','#039'installexamples'#039',SHelpInstExamples);'+
|
|
|
- #010+
|
|
|
- ' LogOption('#039'bu'#039','#039'buildunit'#039',SHelpUseBuildUnit);'#010+
|
|
|
+ 'e,MSG]))'#013#010+
|
|
|
+ ' else'#013#010+
|
|
|
+ ' Log(vlInfo,Format('#039' -%s --%-20s %s'#039',[C,LC+'#039'='#039'+SV'+
|
|
|
+ 'alue,MSG]));'#013#010+
|
|
|
+ ' end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ 'var'#013#010+
|
|
|
+ ' i: Integer;'#013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' // Force the U','sage to be displayed'#013#010+
|
|
|
+ ' Include(FLogLevels,vlInfo);'#013#010+
|
|
|
+ ' If (FMT<>'#039#039') then'#013#010+
|
|
|
+ ' Log(vlInfo,Format(Fmt,Args));'#013#010+
|
|
|
+ ' Log(vlInfo,Format(SHelpUsage,[Paramstr(0)]));'#013#010+
|
|
|
+ ' Log(vlInfo,SHelpCommand);'#013#010+
|
|
|
+ ' LogCmd('#039'compile'#039',SHelpCompile);'#013#010+
|
|
|
+ ' LogCmd('#039'build'#039',S','HelpBuild);'#013#010+
|
|
|
+ ' LogCmd('#039'install'#039',SHelpInstall);'#013#010+
|
|
|
+ ' LogCmd('#039'clean'#039',SHelpClean);'#013#010+
|
|
|
+ ' LogCmd('#039'archive'#039',SHelpArchive);'#013#010+
|
|
|
+ ' LogCmd('#039'manifest'#039',SHelpManifest);'#013#010+
|
|
|
+ ' Log(vlInfo,SHelpCmdOptions);'#013#010+
|
|
|
+ ' LogOption('#039'h'#039','#039'help'#039',SHelpHelp);'#013#010+
|
|
|
+ ' LogOption('#039'l'#039','#039'list','-commands'#039',SHelpList);'#013#010+
|
|
|
+ ' LogOption('#039'n'#039','#039'nofpccfg'#039',SHelpNoFPCCfg);'#013#010+
|
|
|
+ ' LogOption('#039'v'#039','#039'verbose'#039',SHelpVerbose);'#013#010+
|
|
|
+ '{$ifdef HAS_UNIT_PROCESS}'#013#010+
|
|
|
+ ' LogOption('#039'e'#039', '#039'useenv'#039', sHelpUseEnvironment);'#013#010+
|
|
|
+ '{$endif}'#013#010+
|
|
|
+ ' LogOption('#039'ie'#039','#039'installexamples'#039',SHelpIns','tExamples'+
|
|
|
+ ');'#013#010+
|
|
|
+ ' LogOption('#039'bu'#039','#039'buildunit'#039',SHelpUseBuildUnit);'#013#010+
|
|
|
' LogOption('#039'sp'#039','#039'skipcrossprograms'#039',SHelpSkipCrossPro'+
|
|
|
- 'gs);'#010+
|
|
|
- ' LogArgOption('#039'C'#039','#039'cpu'#039',SHelpCPU);'#010+
|
|
|
- ' LogArgOption('#039'O'#039','#039'os'#039',SHelpOS)',';'#010+
|
|
|
- ' LogArgOption('#039't'#039','#039'target'#039',SHelpTarget);'#010+
|
|
|
- ' LogArgOption('#039'P'#039','#039'prefix'#039',SHelpPrefix);'#010+
|
|
|
+ 'gs);'#013#010+
|
|
|
+ ' LogArgOption('#039'C'#039','#039'cpu'#039',SHelpCPU);'#013#010+
|
|
|
+ ' LogArgOption('#039'O'#039','#039'os'#039',SHelpOS);'#013#010+
|
|
|
+ ' LogArgOption('#039't'#039','#039'target'#039',SHelpTarget);'#013#010+
|
|
|
+ ' ','LogArgOption('#039'P'#039','#039'prefix'#039',SHelpPrefix);'#013#010+
|
|
|
' LogArgOption('#039'B'#039','#039'baseinstalldir'#039',SHelpBaseInstalldi'+
|
|
|
- 'r);'#010+
|
|
|
+ 'r);'#013#010+
|
|
|
' LogArgOption('#039'UL'#039','#039'localunitdir'#039',SHelpLocalUnitdir);'+
|
|
|
- #010+
|
|
|
- ' LogArgOption('#039'UG'#039','#039'globalunitdir'#039',SHelp','GlobalUnitd'+
|
|
|
- 'ir);'#010+
|
|
|
- ' LogArgOption('#039'U'#039','#039'unitinstalldir'#039',SHelpUnitInstallDi'+
|
|
|
- 'r);'#010+
|
|
|
- ' LogArgOption('#039'r'#039','#039'compiler'#039',SHelpCompiler);'#010+
|
|
|
- ' LogArgOption('#039'f'#039','#039'config'#039',SHelpConfig);'#010+
|
|
|
- ' LogArgOption('#039'o'#039','#039'options'#039',SHelpOptions);'#010+
|
|
|
- ' LogArgOption('#039'io'#039','#039'ignoreinvalid','option'#039',SHelpIgnor'+
|
|
|
- 'eInvOpt);'#010+
|
|
|
- ' LogArgOption('#039'd'#039', '#039'doc-folder'#039', sHelpFpdocOutputDir)'+
|
|
|
- ';'#010+
|
|
|
- '{$ifndef NO_THREADING}'#010+
|
|
|
- ' LogArgOption('#039'T'#039', '#039'threads'#039', sHelpThreads);'#010+
|
|
|
- '{$endif NO_THREADING}'#010+
|
|
|
- ' if assigned(CustomFpmakeCommandlineOptions) then for i := 0 to',' Cu'+
|
|
|
- 'stomFpmakeCommandlineOptions.Count-1 do'#010+
|
|
|
+ #013#010+
|
|
|
+ ' LogArgOption('#039'UG'#039','#039'globalunitdir'#039',SHelpGlobalUnitdir'+
|
|
|
+ ');'#013#010+
|
|
|
+ ' LogArgOption('#039'U'#039','#039'unitin','stalldir'#039',SHelpUnitInstall'+
|
|
|
+ 'Dir);'#013#010+
|
|
|
+ ' LogArgOption('#039'r'#039','#039'compiler'#039',SHelpCompiler);'#013#010+
|
|
|
+ ' LogArgOption('#039'f'#039','#039'config'#039',SHelpConfig);'#013#010+
|
|
|
+ ' LogArgOption('#039'o'#039','#039'options'#039',SHelpOptions);'#013#010+
|
|
|
+ ' LogArgOption('#039'io'#039','#039'ignoreinvalidoption'#039',SHelpIgnoreI'+
|
|
|
+ 'nvOpt);'#013#010+
|
|
|
+ ' LogArgO','ption('#039'd'#039', '#039'doc-folder'#039', sHelpFpdocOutputDi'+
|
|
|
+ 'r);'#013#010+
|
|
|
+ '{$ifndef NO_THREADING}'#013#010+
|
|
|
+ ' LogArgOption('#039'T'#039', '#039'threads'#039', sHelpThreads);'#013#010+
|
|
|
+ '{$endif NO_THREADING}'#013#010+
|
|
|
+ ' if assigned(CustomFpmakeCommandlineOptions) then for i := 0 to Cust'+
|
|
|
+ 'omFpmakeCommandlineOptions.C','ount-1 do'#013#010+
|
|
|
' LogArgOption('#039' '#039',CustomFpmakeCommandlineOptions.Names[i],C'+
|
|
|
- 'ustomFpmakeCommandlineOptions.ValueFromIndex[i]);'#010+
|
|
|
- ' Log(vlInfo,'#039#039');'#010+
|
|
|
- ' If (FMT<>'#039#039') then'#010+
|
|
|
- ' halt(1)'#010+
|
|
|
- ' else'#010+
|
|
|
- ' halt(0);'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
- #010+
|
|
|
- 'procedur','e TCustomInstaller.Compile(Force: Boolean);'#010+
|
|
|
- 'begin'#010+
|
|
|
- ' FBuildEngine.ForceCompile:=Force;'#010+
|
|
|
- ' FBuildEngine.Compile(Packages);'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
- #010+
|
|
|
- 'procedure TCustomInstaller.Clean(AllTargets: boolean);'#010+
|
|
|
- 'begin'#010+
|
|
|
- ' BuildEngine.Clean(Packages, AllTargets);'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
- #010+
|
|
|
- 'pr','ocedure TCustomInstaller.Install;'#010+
|
|
|
- 'begin'#010+
|
|
|
- ' BuildEngine.Install(Packages);'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
- 'procedure TCustomInstaller.ZipInstall;'#010+
|
|
|
- 'begin'#010+
|
|
|
- ' BuildEngine.ZipInstall(Packages);'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
- #010+
|
|
|
- 'procedure TCustomInstaller.Archive;'#010+
|
|
|
- 'begin'#010+
|
|
|
- ' // Force generation of manife','st.xml, this is required for the repo'+
|
|
|
- 'sitory'#010+
|
|
|
- ' BuildEngine.Manifest(Packages);'#010+
|
|
|
- ' BuildEngine.Archive(Packages);'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
- #010+
|
|
|
- 'procedure TCustomInstaller.Manifest;'#010+
|
|
|
- 'begin'#010+
|
|
|
- ' BuildEngine.Manifest(Packages);'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
- #010+
|
|
|
- 'procedure TCustomInstaller.CheckPackag','es;'#010+
|
|
|
- 'begin'#010+
|
|
|
- ' If (Packages.Count=0) then'#010+
|
|
|
- ' Error(SErrNoPackagesDefined);'#010+
|
|
|
- ' // Check for other obvious errors ?'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
- #010+
|
|
|
- 'Function TCustomInstaller.Run : Boolean;'#010+
|
|
|
- 'begin'#010+
|
|
|
- ' Result:=True;'#010+
|
|
|
- ' try'#010+
|
|
|
- ' CheckPackages;'#010+
|
|
|
- ' CreateBuildEngine;'#010+
|
|
|
- ' Case Ru','nMode of'#010+
|
|
|
- ' rmCompile : Compile(False);'#010+
|
|
|
- ' rmBuild : Compile(True);'#010+
|
|
|
- ' rmInstall : Install;'#010+
|
|
|
- ' rmZipInstall : ZipInstall;'#010+
|
|
|
- ' rmArchive : Archive;'#010+
|
|
|
- ' rmClean : Clean(False);'#010+
|
|
|
- ' rmDistClean: Clean(True);'#010+
|
|
|
- ' rmMani','fest : Manifest;'#010+
|
|
|
- ' end;'#010+
|
|
|
- ' except'#010+
|
|
|
- ' On E : Exception do'#010+
|
|
|
- ' begin'#010+
|
|
|
- ' Log(vlError,SErrInstaller);'#010+
|
|
|
- ' Log(vlError,E.Message);'#010+
|
|
|
- ' Result:=False;'#010+
|
|
|
- ' end;'#010+
|
|
|
- ' end;'#010+
|
|
|
- ' // Force returning an exitcode to the shell'#010+
|
|
|
- ' if not Result then',#010+
|
|
|
- ' ExitCode:=1;'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
- #010+
|
|
|
+ 'ustomFpmakeCommandlineOptions.ValueFromIndex[i]);'#013#010+
|
|
|
+ ' Log(vlInfo,'#039#039');'#013#010+
|
|
|
+ ' If (FMT<>'#039#039') then'#013#010+
|
|
|
+ ' halt(1)'#013#010+
|
|
|
+ ' else'#013#010+
|
|
|
+ ' halt(0);'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ #013#010+
|
|
|
+ 'procedure TCustomInstaller.Comp','ile(Force: Boolean);'#013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' FBuildEngine.ForceCompile:=Force;'#013#010+
|
|
|
+ ' FBuildEngine.Compile(Packages);'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ #013#010+
|
|
|
+ 'procedure TCustomInstaller.Clean(AllTargets: boolean);'#013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' BuildEngine.Clean(Packages, AllTargets);'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ #013#010+
|
|
|
+ 'procedure TC','ustomInstaller.Install;'#013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' BuildEngine.Install(Packages);'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ 'procedure TCustomInstaller.ZipInstall;'#013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' BuildEngine.ZipInstall(Packages);'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ #013#010+
|
|
|
+ 'procedure TCustomInstaller.Archive;'#013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' // Force generation of man','ifest.xml, this is required for the repo'+
|
|
|
+ 'sitory'#013#010+
|
|
|
+ ' BuildEngine.Manifest(Packages);'#013#010+
|
|
|
+ ' BuildEngine.Archive(Packages);'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ #013#010+
|
|
|
+ 'procedure TCustomInstaller.Manifest;'#013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' BuildEngine.Manifest(Packages);'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ #013#010+
|
|
|
+ 'procedure TCustomInstal','ler.CheckPackages;'#013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' If (Packages.Count=0) then'#013#010+
|
|
|
+ ' Error(SErrNoPackagesDefined);'#013#010+
|
|
|
+ ' // Check for other obvious errors ?'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ #013#010+
|
|
|
+ 'Function TCustomInstaller.Run : Boolean;'#013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' Result:=True;'#013#010+
|
|
|
+ ' try'#013#010+
|
|
|
+ ' CheckPackages;'#013#010+
|
|
|
+ ' Cr','eateBuildEngine;'#013#010+
|
|
|
+ ' Case RunMode of'#013#010+
|
|
|
+ ' rmCompile : Compile(False);'#013#010+
|
|
|
+ ' rmBuild : Compile(True);'#013#010+
|
|
|
+ ' rmInstall : Install;'#013#010+
|
|
|
+ ' rmZipInstall : ZipInstall;'#013#010+
|
|
|
+ ' rmArchive : Archive;'#013#010+
|
|
|
+ ' rmClean : Clean(False);'#013#010+
|
|
|
+ ' rm','DistClean: Clean(True);'#013#010+
|
|
|
+ ' rmManifest : Manifest;'#013#010+
|
|
|
+ ' end;'#013#010+
|
|
|
+ ' except'#013#010+
|
|
|
+ ' On E : Exception do'#013#010+
|
|
|
+ ' begin'#013#010+
|
|
|
+ ' Log(vlError,SErrInstaller);'#013#010+
|
|
|
+ ' Log(vlError,E.Message);'#013#010+
|
|
|
+ ' Result:=False;'#013#010+
|
|
|
+ ' end;'#013#010+
|
|
|
+ ' end;'#013#010+
|
|
|
+ ' // Force returnin','g an exitcode to the shell'#013#010+
|
|
|
+ ' if not Result then'#013#010+
|
|
|
+ ' ExitCode:=1;'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ #013#010+
|
|
|
+ '{*********************************************************************'+
|
|
|
+ '*******'#013#010+
|
|
|
+ ' TFPCInstaller'#013#010+
|
|
|
+ '************************************','********************************'+
|
|
|
+ '********}'#013#010+
|
|
|
+ #013#010+
|
|
|
+ 'constructor TFPCInstaller.Create(AOwner: TComponent);'#013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' if assigned(Defaults) then'#013#010+
|
|
|
+ ' Error(SErrAlreadyInitialized);'#013#010+
|
|
|
+ ' Defaults:=TFPCDefaults.Create;'#013#010+
|
|
|
+ ' inherited Create(AOwner);'#013#010+
|
|
|
+ 'end;',#013#010+
|
|
|
+ #013#010+
|
|
|
+ #013#010+
|
|
|
'{*********************************************************************'+
|
|
|
- '*******'#010+
|
|
|
- ' TFPCInstaller'#010+
|
|
|
+ '*******'#013#010+
|
|
|
+ ' TBasicInstaller'#013#010+
|
|
|
'**********************************************************************'+
|
|
|
- '******}'#010+
|
|
|
- #010+
|
|
|
- 'constructor ','TFPCInstaller.Create(AOwner: TComponent);'#010+
|
|
|
- 'begin'#010+
|
|
|
- ' if assigned(Defaults) then'#010+
|
|
|
- ' Error(SErrAlreadyInitialized);'#010+
|
|
|
- ' Defaults:=TFPCDefaults.Create;'#010+
|
|
|
- ' inherited Create(AOwner);'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
- #010+
|
|
|
- '{***********************************************************','********'+
|
|
|
- '*********'#010+
|
|
|
- ' TBasicInstaller'#010+
|
|
|
+ '******}'#013#010+
|
|
|
+ #013#010+
|
|
|
+ 'constructor TBasicInstal','ler.Create(AOwner: TComponent);'#013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' if assigned(Defaults) then'#013#010+
|
|
|
+ ' Error(SErrAlreadyInitialized);'#013#010+
|
|
|
+ ' Defaults:=TBasicDefaults.Create;'#013#010+
|
|
|
+ ' inherited Create(AOwner);'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ #013#010+
|
|
|
+ '{**********************************************************','*********'+
|
|
|
+ '*********'#013#010+
|
|
|
+ ' TBuildEngine'#013#010+
|
|
|
'**********************************************************************'+
|
|
|
- '******}'#010+
|
|
|
- #010+
|
|
|
- 'constructor TBasicInstaller.Create(AOwner: TComponent);'#010+
|
|
|
- 'begin'#010+
|
|
|
- ' if assigned(Defaults) then'#010+
|
|
|
- ' ',' Error(SErrAlreadyInitialized);'#010+
|
|
|
- ' Defaults:=TBasicDefaults.Create;'#010+
|
|
|
- ' inherited Create(AOwner);'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
- #010+
|
|
|
- '{*********************************************************************'+
|
|
|
- '*******'#010+
|
|
|
- ' TBuildEngine'#010+
|
|
|
- '**************','******************************************************'+
|
|
|
- '********}'#010+
|
|
|
- #010+
|
|
|
- 'constructor TBuildEngine.Create(AOwner: TComponent);'#010+
|
|
|
- 'begin'#010+
|
|
|
- ' inherited Create(AOwner);'#010+
|
|
|
- ' // Maybe this should be the current directory ?'#010+
|
|
|
- ' // Or have it as a command-line opti','on.'#010+
|
|
|
+ '******}'#013#010+
|
|
|
+ #013#010+
|
|
|
+ 'constructor TBuildEngine.Create(AOwner: TComponent);'#013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' inherited Create(AOwner);'#013#010+
|
|
|
+ ' ','// Maybe this should be the current directory ?'#013#010+
|
|
|
+ ' // Or have it as a command-line option.'#013#010+
|
|
|
' // Would allow to put all '#039'installers'#039' in one dir and call t'+
|
|
|
- 'hem'#010+
|
|
|
- ' // With --start-dir=/path/to/sources.'#010+
|
|
|
- ' FStartDir:=includeTrailingPathDelimiter(GetCurrentDir);'#010+
|
|
|
- ' FExternalPackages:=TPackages.Create(TPackage);'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
- #010+
|
|
|
- 'destructor TBuil','dEngine.Destroy;'#010+
|
|
|
- 'begin'#010+
|
|
|
- ' FreeAndNil(FExternalPackages);'#010+
|
|
|
- ' inherited Destroy;'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
- #010+
|
|
|
- 'procedure TBuildEngine.Error(const Msg: String);'#010+
|
|
|
- 'begin'#010+
|
|
|
- ' Raise EInstallerError.Create(Msg);'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
- #010+
|
|
|
- 'procedure TBuildEngine.Error(const Fmt: String; const Arg','s: array of'+
|
|
|
- ' const);'#010+
|
|
|
- 'begin'#010+
|
|
|
- ' Raise EInstallerError.CreateFmt(Fmt,Args);'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
- #010+
|
|
|
- 'procedure TBuildEngine.ExecuteCommand(const Cmd,Args : String; const E'+
|
|
|
- 'nv: TStrings = nil; IgnoreError : Boolean = False);'#010+
|
|
|
- 'Var'#010+
|
|
|
- ' E : Integer;'#010+
|
|
|
- ' cmdLine: string;'#010+
|
|
|
- ' ','ConsoleOutput: TMemoryStream;'#010+
|
|
|
- ' s: string;'#010+
|
|
|
- 'begin'#010+
|
|
|
- ' Log(vlInfo,SInfoExecutingCommand,[Cmd,Args]);'#010+
|
|
|
- ' if ListMode then'#010+
|
|
|
- ' Log(vlCommand,'#039'%s %s'#039',[Cmd,Args])'#010+
|
|
|
- ' else'#010+
|
|
|
- ' begin'#010+
|
|
|
- ' // We should check cmd for spaces, and move all after first spa',
|
|
|
- 'ce to args.'#010+
|
|
|
- ' ConsoleOutput := TMemoryStream.Create;'#010+
|
|
|
- ' try'#010+
|
|
|
- ' {$ifdef HAS_UNIT_PROCESS}'#010+
|
|
|
- ' E:=ExecuteFPC(Verbose, cmd, args, env, ConsoleOutput);'#010+
|
|
|
- ' {$else}'#010+
|
|
|
- ' E:=ExecuteProcess(cmd,args);'#010+
|
|
|
- ' {$endif}'#010+
|
|
|
- ' ',' If (E<>0) and (not IgnoreError) then'#010+
|
|
|
- ' begin'#010+
|
|
|
- ' if trim(Args)<>'#039#039' then'#010+
|
|
|
- ' cmdLine := cmd + '#039' '#039' + trim(args)'#010+
|
|
|
- ' else'#010+
|
|
|
- ' cmdline := cmd;'#010+
|
|
|
- ' s := ParsecompilerOutput(ConsoleOutput,Verb','ose);'#010+
|
|
|
- ' Error(SErrExternalCommandFailed,[cmdLine,E,s]);'#010+
|
|
|
- ' end;'#010+
|
|
|
- ' finally'#010+
|
|
|
- ' ConsoleOutput.Free;'#010+
|
|
|
- ' end;'#010+
|
|
|
- ' end;'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
- #010+
|
|
|
- 'Function TBuildEngine.SysDirectoryExists(const ADir:string):Boolean;'#010+
|
|
|
- 'begin'#010+
|
|
|
- ' result:=SysUt','ils.DirectoryExists(ADir);'#010+
|
|
|
- ' if result then'#010+
|
|
|
- ' Log(vlDebug,SDbgDirectoryExists,[ADir,SDbgFound])'#010+
|
|
|
- ' else'#010+
|
|
|
- ' Log(vlDebug,SDbgDirectoryExists,[ADir,SDbgNotFound]);'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
- #010+
|
|
|
- 'Function TBuildEngine.SysFileExists(const AFileName:string):Boolean;'#010+
|
|
|
- 'b','egin'#010+
|
|
|
- ' result:=SysUtils.FileExists(AFileName);'#010+
|
|
|
- ' if result then'#010+
|
|
|
- ' Log(vlDebug,SDbgFileExists,[AFileName,SDbgFound])'#010+
|
|
|
- ' else'#010+
|
|
|
- ' Log(vlDebug,SDbgFileExists,[AFileName,SDbgNotFound]);'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
- #010+
|
|
|
- 'procedure TBuildEngine.SysCopyFile(Const Src,Dest ',': String);'#010+
|
|
|
- 'Var'#010+
|
|
|
- ' D,S : String;'#010+
|
|
|
- ' Fin,FOut : TFileStream;'#010+
|
|
|
- ' Count : Int64;'#010+
|
|
|
- ' A : Integer;'#010+
|
|
|
- '{$ifdef UNIX}'#010+
|
|
|
- ' FileStat: stat;'#010+
|
|
|
- '{$endif UNIX}'#010+
|
|
|
- 'begin'#010+
|
|
|
- ' Log(vlInfo,SInfoCopyingFile,[Src,Dest]);'#010+
|
|
|
- ' FIn:=TFileStream.Create(Src,fmopenRead);'#010+
|
|
|
- ' Try'#010+
|
|
|
- ' D:=','IncludeTrailingPathDelimiter(Dest);'#010+
|
|
|
- ' If DirectoryExists(D) then'#010+
|
|
|
- ' S:=D+ExtractFileName(Src)'#010+
|
|
|
- ' else'#010+
|
|
|
- ' S:=Dest;'#010+
|
|
|
- ' FOut:=TFileStream.Create(S,fmCreate);'#010+
|
|
|
- ' Try'#010+
|
|
|
- ' Count:=Fout.CopyFrom(FIn,0);'#010+
|
|
|
- ' If (Count<>Fin.Size) then'#010,
|
|
|
- ' Error(SErrCopyingFile,[Src,S]);'#010+
|
|
|
- ' Finally'#010+
|
|
|
- ' FreeAndNil(Fout);'#010+
|
|
|
- ' end;'#010+
|
|
|
- ' A:=FileGetDate(FIn.Handle);'#010+
|
|
|
- ' If (A=-1) then'#010+
|
|
|
- ' log(vlWarning,SWarnFailedToGetTime,[Src])'#010+
|
|
|
- ' else'#010+
|
|
|
- ' if FileSetDate(S,A)<>0 then'#010+
|
|
|
- ' Log(v','lWarning,SWarnFailedToSetTime,[S]);'#010+
|
|
|
- '{$ifdef UNIX}'#010+
|
|
|
+ 'hem'#013#010+
|
|
|
+ ' // With --start-dir=/path/to/sources.'#013#010+
|
|
|
+ ' FStartDir:=includeTrailingPathDelimite','r(GetCurrentDir);'#013#010+
|
|
|
+ ' FExternalPackages:=TPackages.Create(TPackage);'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ #013#010+
|
|
|
+ 'destructor TBuildEngine.Destroy;'#013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' FreeAndNil(FExternalPackages);'#013#010+
|
|
|
+ ' inherited Destroy;'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ #013#010+
|
|
|
+ 'procedure TBuildEngine.Error(const Msg: String);'#013#010+
|
|
|
+ 'begi','n'#013#010+
|
|
|
+ ' Raise EInstallerError.Create(Msg);'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ #013#010+
|
|
|
+ 'procedure TBuildEngine.Error(const Fmt: String; const Args: array of c'+
|
|
|
+ 'onst);'#013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' Raise EInstallerError.CreateFmt(Fmt,Args);'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ #013#010+
|
|
|
+ 'procedure TBuildEngine.ExecuteCommand(const Cmd,','Args : String; const'+
|
|
|
+ ' Env: TStrings = nil; IgnoreError : Boolean = False);'#013#010+
|
|
|
+ 'Var'#013#010+
|
|
|
+ ' E : Integer;'#013#010+
|
|
|
+ ' cmdLine: string;'#013#010+
|
|
|
+ ' ConsoleOutput: TMemoryStream;'#013#010+
|
|
|
+ ' s: string;'#013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' Log(vlInfo,SInfoExecutingCommand,[Cmd,Args]);'#013#010+
|
|
|
+ ' if ListMode then'#013#010+
|
|
|
+ ' ',' Log(vlCommand,'#039'%s %s'#039',[Cmd,Args])'#013#010+
|
|
|
+ ' else'#013#010+
|
|
|
+ ' begin'#013#010+
|
|
|
+ ' // We should check cmd for spaces, and move all after first spac'+
|
|
|
+ 'e to args.'#013#010+
|
|
|
+ ' ConsoleOutput := TMemoryStream.Create;'#013#010+
|
|
|
+ ' try'#013#010+
|
|
|
+ ' {$ifdef HAS_UNIT_PROCESS}'#013#010+
|
|
|
+ ' E',':=ExecuteFPC(Verbose, cmd, args, env, ConsoleOutput);'#013#010+
|
|
|
+ ' {$else}'#013#010+
|
|
|
+ ' E:=ExecuteProcess(cmd,args);'#013#010+
|
|
|
+ ' {$endif}'#013#010+
|
|
|
+ ' If (E<>0) and (not IgnoreError) then'#013#010+
|
|
|
+ ' begin'#013#010+
|
|
|
+ ' if trim(Args)<>'#039#039' then'#013#010+
|
|
|
+ ' ',' cmdLine := cmd + '#039' '#039' + trim(args)'#013#010+
|
|
|
+ ' else'#013#010+
|
|
|
+ ' cmdline := cmd;'#013#010+
|
|
|
+ ' s := ParsecompilerOutput(ConsoleOutput,Verbose);'#013#010+
|
|
|
+ ' Error(SErrExternalCommandFailed,[cmdLine,E,s]);'#013#010+
|
|
|
+ ' end;'#013#010+
|
|
|
+ ' finally'#013#010+
|
|
|
+ ' ',' ConsoleOutput.Free;'#013#010+
|
|
|
+ ' end;'#013#010+
|
|
|
+ ' end;'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ #013#010+
|
|
|
+ 'Function TBuildEngine.SysDirectoryExists(const ADir:string):Boolean;'#013+
|
|
|
+ #010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' result:=SysUtils.DirectoryExists(ADir);'#013#010+
|
|
|
+ ' if result then'#013#010+
|
|
|
+ ' Log(vlDebug,SDbgDirectoryExists,[ADir,','SDbgFound])'#013#010+
|
|
|
+ ' else'#013#010+
|
|
|
+ ' Log(vlDebug,SDbgDirectoryExists,[ADir,SDbgNotFound]);'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ #013#010+
|
|
|
+ 'Function TBuildEngine.SysFileExists(const AFileName:string):Boolean;'#013+
|
|
|
+ #010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' result:=SysUtils.FileExists(AFileName);'#013#010+
|
|
|
+ ' if result then'#013#010+
|
|
|
+ ' Log(vlDe','bug,SDbgFileExists,[AFileName,SDbgFound])'#013#010+
|
|
|
+ ' else'#013#010+
|
|
|
+ ' Log(vlDebug,SDbgFileExists,[AFileName,SDbgNotFound]);'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ #013#010+
|
|
|
+ 'procedure TBuildEngine.SysCopyFile(Const Src,Dest : String);'#013#010+
|
|
|
+ 'Var'#013#010+
|
|
|
+ ' D,S : String;'#013#010+
|
|
|
+ ' Fin,FOut : TFileStream;'#013#010+
|
|
|
+ ' Count :',' Int64;'#013#010+
|
|
|
+ ' A : Integer;'#013#010+
|
|
|
+ '{$ifdef UNIX}'#013#010+
|
|
|
+ ' FileStat: stat;'#013#010+
|
|
|
+ '{$endif UNIX}'#013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' Log(vlInfo,SInfoCopyingFile,[Src,Dest]);'#013#010+
|
|
|
+ ' FIn:=TFileStream.Create(Src,fmopenRead);'#013#010+
|
|
|
+ ' Try'#013#010+
|
|
|
+ ' D:=IncludeTrailingPathDelimiter(Dest);'#013#010+
|
|
|
+ ' If DirectoryExis','ts(D) then'#013#010+
|
|
|
+ ' S:=D+ExtractFileName(Src)'#013#010+
|
|
|
+ ' else'#013#010+
|
|
|
+ ' S:=Dest;'#013#010+
|
|
|
+ ' FOut:=TFileStream.Create(S,fmCreate);'#013#010+
|
|
|
+ ' Try'#013#010+
|
|
|
+ ' Count:=Fout.CopyFrom(FIn,0);'#013#010+
|
|
|
+ ' If (Count<>Fin.Size) then'#013#010+
|
|
|
+ ' Error(SErrCopyingFile,[Src,S]);'#013#010+
|
|
|
+ ' Fin','ally'#013#010+
|
|
|
+ ' FreeAndNil(Fout);'#013#010+
|
|
|
+ ' end;'#013#010+
|
|
|
+ ' A:=FileGetDate(FIn.Handle);'#013#010+
|
|
|
+ ' If (A=-1) then'#013#010+
|
|
|
+ ' log(vlWarning,SWarnFailedToGetTime,[Src])'#013#010+
|
|
|
+ ' else'#013#010+
|
|
|
+ ' if FileSetDate(S,A)<>0 then'#013#010+
|
|
|
+ ' Log(vlWarning,SWarnFailedToSetTime,[S]);'#013#010+
|
|
|
+ '{$','ifdef UNIX}'#013#010+
|
|
|
' // Copy the file-access rights on Unix, especially the executable-'+
|
|
|
- 'bit'#010+
|
|
|
- ' if FpStat(Src,FileStat) <> 0 then'#010+
|
|
|
- ' Log(vlWarning,SWarnCanNotGetAccessRights,[Src])'#010+
|
|
|
- ' else'#010+
|
|
|
- ' if FpChmo','d(s,FileStat.st_mode) <> 0 then'#010+
|
|
|
- ' Log(vlWarning,SWarnCanNotSetAccessRights,[S]);'#010+
|
|
|
- '{$endif UNIX}'#010+
|
|
|
- ' finally'#010+
|
|
|
- ' FreeAndNil(Fin);'#010+
|
|
|
- ' end;'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
- #010+
|
|
|
- 'procedure TBuildEngine.SysMoveFile(Const Src,Dest : String);'#010+
|
|
|
- 'Var'#010+
|
|
|
- ' S : String;'#010+
|
|
|
- 'begin'#010+
|
|
|
- ' If Dire','ctoryExists(IncludeTrailingPathDelimiter(Dest)) then'#010+
|
|
|
- ' S:=IncludeTrailingPathDelimiter(Dest)+ExtractFileName(Src)'#010+
|
|
|
- ' else'#010+
|
|
|
- ' S:=Dest;'#010+
|
|
|
- ' If Not RenameFile(Src,S) then'#010+
|
|
|
- ' begin'#010+
|
|
|
- ' Try'#010+
|
|
|
- ' SysCopyFile(Src,S);'#010+
|
|
|
- ' SysDeleteFile(Sr','c);'#010+
|
|
|
- ' Except'#010+
|
|
|
- ' On E : Exception Do'#010+
|
|
|
- ' Error(SErrMovingFile,[Src,S]);'#010+
|
|
|
- ' end;'#010+
|
|
|
- ' end;'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
- #010+
|
|
|
- 'procedure TBuildEngine.SysDeleteFile(Const AFileName : String);'#010+
|
|
|
- 'begin'#010+
|
|
|
- ' Log(vlInfo,SInfoDeletingFile,[AFileName]);'#010+
|
|
|
- ' if not Fil','eExists(AFileName) then'#010+
|
|
|
- ' Log(vldebug,SDbgFileDoesNotExist,[AFileName])'#010+
|
|
|
- ' else If Not DeleteFile(AFileName) then'#010+
|
|
|
- ' Error(SErrDeletingFile,[AFileName]);'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
+ 'bit'#013#010+
|
|
|
+ ' if FpStat(Src,FileStat) <> 0 then'#013#010+
|
|
|
+ ' Log(vlWarning,SWarnCanNotGetAccessRights,[Src])'#013#010+
|
|
|
+ ' else'#013#010+
|
|
|
+ ' if FpChmod(s,FileStat.st_mode) <> 0 then'#013#010,
|
|
|
+ ' Log(vlWarning,SWarnCanNotSetAccessRights,[S]);'#013#010+
|
|
|
+ '{$endif UNIX}'#013#010+
|
|
|
+ ' finally'#013#010+
|
|
|
+ ' FreeAndNil(Fin);'#013#010+
|
|
|
+ ' end;'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ #013#010+
|
|
|
+ 'procedure TBuildEngine.SysMoveFile(Const Src,Dest : String);'#013#010+
|
|
|
+ 'Var'#013#010+
|
|
|
+ ' S : String;'#013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' If DirectoryExists(IncludeT','railingPathDelimiter(Dest)) then'#013#010+
|
|
|
+ ' S:=IncludeTrailingPathDelimiter(Dest)+ExtractFileName(Src)'#013#010+
|
|
|
+ ' else'#013#010+
|
|
|
+ ' S:=Dest;'#013#010+
|
|
|
+ ' If Not RenameFile(Src,S) then'#013#010+
|
|
|
+ ' begin'#013#010+
|
|
|
+ ' Try'#013#010+
|
|
|
+ ' SysCopyFile(Src,S);'#013#010+
|
|
|
+ ' SysDeleteFile(Src);'#013#010+
|
|
|
+ ' E','xcept'#013#010+
|
|
|
+ ' On E : Exception Do'#013#010+
|
|
|
+ ' Error(SErrMovingFile,[Src,S]);'#013#010+
|
|
|
+ ' end;'#013#010+
|
|
|
+ ' end;'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ #013#010+
|
|
|
+ 'procedure TBuildEngine.SysDeleteFile(Const AFileName : String);'#013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' Log(vlInfo,SInfoDeletingFile,[AFileName]);'#013#010+
|
|
|
+ ' if not Fil','eExists(AFileName) then'#013#010+
|
|
|
+ ' Log(vldebug,SDbgFileDoesNotExist,[AFileName])'#013#010+
|
|
|
+ ' else If Not DeleteFile(AFileName) then'#013#010+
|
|
|
+ ' Error(SErrDeletingFile,[AFileName]);'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
'procedure TBuildEngine.SysDeleteDirectory(Const ADirectoryName: String'+
|
|
|
- ');'#010+
|
|
|
- 'begin',#010+
|
|
|
- ' if not DirectoryExists(ADirectoryName) then'#010+
|
|
|
- ' Log(vldebug,SDbgDirectoryDoesNotExist,[ADirectoryName])'#010+
|
|
|
- ' else if not IsDirectoryEmpty(ADirectoryName) then'#010+
|
|
|
- ' Log(vldebug,SDbgDirectoryNotEmpty,[ADirectoryName])'#010+
|
|
|
- ' else If Not RemoveDir(A','DirectoryName) then'#010+
|
|
|
- ' Error(SErrRemovingDirectory,[ADirectoryName]);'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
- #010+
|
|
|
- 'procedure TBuildEngine.SysDeleteTree(Const ADirectoryName: String);'#010+
|
|
|
- #010+
|
|
|
- ' function IntRemoveTree(const ADirectoryName: String) : boolean;'#010+
|
|
|
- ' var'#010+
|
|
|
- ' searchRec: TSearc','hRec;'#010+
|
|
|
- ' SearchResult: longint;'#010+
|
|
|
- ' begin'#010+
|
|
|
- ' result := true;'#010+
|
|
|
+ ');',#013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' if not DirectoryExists(ADirectoryName) then'#013#010+
|
|
|
+ ' Log(vldebug,SDbgDirectoryDoesNotExist,[ADirectoryName])'#013#010+
|
|
|
+ ' else if not IsDirectoryEmpty(ADirectoryName) then'#013#010+
|
|
|
+ ' Log(vldebug,SDbgDirectoryNotEmpty,[ADirectoryName])'#013#010+
|
|
|
+ ' else If Not',' RemoveDir(ADirectoryName) then'#013#010+
|
|
|
+ ' Error(SErrRemovingDirectory,[ADirectoryName]);'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ #013#010+
|
|
|
+ 'procedure TBuildEngine.SysDeleteTree(Const ADirectoryName: String);'#013+
|
|
|
+ #010+
|
|
|
+ #013#010+
|
|
|
+ ' function IntRemoveTree(const ADirectoryName: String) : boolean;'#013#010+
|
|
|
+ ' var'#013#010,
|
|
|
+ ' searchRec: TSearchRec;'#013#010+
|
|
|
+ ' SearchResult: longint;'#013#010+
|
|
|
+ ' begin'#013#010+
|
|
|
+ ' result := true;'#013#010+
|
|
|
' SearchResult := FindFirst(IncludeTrailingPathDelimiter(ADirectoryN'+
|
|
|
- 'ame)+AllFilesMask, faAnyFile+faSymLink, searchRec);'#010+
|
|
|
- ' try'#010+
|
|
|
- ' while SearchResult=0 do'#010+
|
|
|
- ' begin'#010+
|
|
|
- ' ',' if (searchRec.Name<>'#039'.'#039') and (searchRec.Name<>'#039+
|
|
|
- '..'#039') then'#010+
|
|
|
- ' begin'#010+
|
|
|
- ' if (searchRec.Attr and faDirectory)=faDirectory then'#010+
|
|
|
- ' begin'#010+
|
|
|
- ' if not IntRemoveTree(IncludeTrailingPathDelimiter','('+
|
|
|
- 'ADirectoryName)+searchRec.Name) then'#010+
|
|
|
- ' result := false;'#010+
|
|
|
- ' end'#010+
|
|
|
+ 'ame)+AllFilesMask, faAnyFile+faSymLink, searchRec);'#013#010+
|
|
|
+ ' try'#013#010+
|
|
|
+ ' while SearchResu','lt=0 do'#013#010+
|
|
|
+ ' begin'#013#010+
|
|
|
+ ' if (searchRec.Name<>'#039'.'#039') and (searchRec.Name<>'#039'.'+
|
|
|
+ '.'#039') then'#013#010+
|
|
|
+ ' begin'#013#010+
|
|
|
+ ' if (searchRec.Attr and faDirectory)=faDirectory then'#013+
|
|
|
+ #010+
|
|
|
+ ' begin'#013#010+
|
|
|
+ ' if not IntRemove','Tree(IncludeTrailingPathDelimiter'+
|
|
|
+ '(ADirectoryName)+searchRec.Name) then'#013#010+
|
|
|
+ ' result := false;'#013#010+
|
|
|
+ ' end'#013#010+
|
|
|
' else if not DeleteFile(IncludeTrailingPathDelimiter(ADi'+
|
|
|
- 'rectoryName)+searchRec.Name) then'#010+
|
|
|
- ' result := False;'#010+
|
|
|
- ' ',' end;'#010+
|
|
|
- ' SearchResult := FindNext(searchRec);'#010+
|
|
|
- ' end;'#010+
|
|
|
- ' finally'#010+
|
|
|
- ' FindClose(searchRec);'#010+
|
|
|
- ' end;'#010+
|
|
|
- ' if not RemoveDir(ADirectoryName) then'#010+
|
|
|
- ' result := false;'#010+
|
|
|
- ' end;'#010+
|
|
|
- #010+
|
|
|
- 'begin'#010+
|
|
|
- ' if not DirectoryExists(ADirectoryName',') then'#010+
|
|
|
- ' Log(vldebug,SDbgDirectoryDoesNotExist,[ADirectoryName])'#010+
|
|
|
- ' else If Not IntRemoveTree(ADirectoryName) then'#010+
|
|
|
- ' Error(SErrRemovingDirectory,[ADirectoryName]);'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
- #010+
|
|
|
- 'procedure TBuildEngine.SysArchiveFiles(List: TStrings;Const AFileN','am'+
|
|
|
- 'e: String);'#010+
|
|
|
- 'begin'#010+
|
|
|
+ 'rectoryName)+searchRec.Name) then'#013#010+
|
|
|
+ ' ',' result := False;'#013#010+
|
|
|
+ ' end;'#013#010+
|
|
|
+ ' SearchResult := FindNext(searchRec);'#013#010+
|
|
|
+ ' end;'#013#010+
|
|
|
+ ' finally'#013#010+
|
|
|
+ ' FindClose(searchRec);'#013#010+
|
|
|
+ ' end;'#013#010+
|
|
|
+ ' if not RemoveDir(ADirectoryName) then'#013#010+
|
|
|
+ ' result := false;'#013#010+
|
|
|
+ ' end;'#013,#010+
|
|
|
+ #013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' if not DirectoryExists(ADirectoryName) then'#013#010+
|
|
|
+ ' Log(vldebug,SDbgDirectoryDoesNotExist,[ADirectoryName])'#013#010+
|
|
|
+ ' else If Not IntRemoveTree(ADirectoryName) then'#013#010+
|
|
|
+ ' Error(SErrRemovingDirectory,[ADirectoryName]);'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ #013#010+
|
|
|
+ 'procedure ','TBuildEngine.SysArchiveFiles(List: TStrings;Const AFileNam'+
|
|
|
+ 'e: String);'#013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
' If Not (Assigned(OnArchivefiles) or Assigned(ArchiveFilesProc)) then'+
|
|
|
- #010+
|
|
|
- ' Raise EInstallerError.Create(SErrNoArchiveSupport);'#010+
|
|
|
- ' If Assigned(ArchiveFilesProc) then'#010+
|
|
|
- ' ArchiveFilesProc(AFileName,List)'#010+
|
|
|
- ' else'#010+
|
|
|
- ' OnArchiv','eFiles(AFileName,List);'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
- #010+
|
|
|
- 'procedure TBuildEngine.LogIndent;'#010+
|
|
|
- 'begin'#010+
|
|
|
- ' GLogPrefix:=GLogPrefix+'#039' '#039';'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
- #010+
|
|
|
- 'procedure TBuildEngine.LogUnIndent;'#010+
|
|
|
- 'begin'#010+
|
|
|
- ' Delete(GLogPrefix,1,2);'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
- #010+
|
|
|
- 'procedure TBuildEngine.Log(Level: TVerboseLevel; Msg: St','ring);'#010+
|
|
|
- 'begin'#010+
|
|
|
- ' If Assigned(FOnLog) then'#010+
|
|
|
- ' begin'#010+
|
|
|
- ' if Level in [vlInfo,vlDebug] then'#010+
|
|
|
- ' FOnLog(Level,GLogPrefix+Msg)'#010+
|
|
|
- ' else'#010+
|
|
|
- ' FOnLog(Level,Msg);'#010+
|
|
|
- ' end;'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
- #010+
|
|
|
- 'procedure TBuildEngine.Log(Level: TVerboseLevel; Fmt: Strin','g;const A'+
|
|
|
- 'rgs: array of const);'#010+
|
|
|
- 'begin'#010+
|
|
|
- ' Log(Level,Format(Fmt,Args));'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
- #010+
|
|
|
- 'procedure TBuildEngine.EnterDir(ADir: String);'#010+
|
|
|
- 'Var'#010+
|
|
|
- ' D : String;'#010+
|
|
|
- 'begin'#010+
|
|
|
- ' D:=FStartDir;'#010+
|
|
|
- ' D:=D+ADir;'#010+
|
|
|
- ' Log(vlDebug,SDbgEnterDir,[D]);'#010+
|
|
|
- ' If Not SetCurrentDir(D) then'#010+
|
|
|
- ' ',' Error(SErrChangeDirFailed,[D]);'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
- #010+
|
|
|
+ #013#010+
|
|
|
+ ' Raise EInstallerError.Create(SErrNoArchiveSupport);'#013#010+
|
|
|
+ ' If Assigned(ArchiveFilesProc) t','hen'#013#010+
|
|
|
+ ' ArchiveFilesProc(AFileName,List)'#013#010+
|
|
|
+ ' else'#013#010+
|
|
|
+ ' OnArchiveFiles(AFileName,List);'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ #013#010+
|
|
|
+ 'procedure TBuildEngine.LogIndent;'#013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' GLogPrefix:=GLogPrefix+'#039' '#039';'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ #013#010+
|
|
|
+ 'procedure TBuildEngine.LogUnIndent;'#013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' Delete(GLogP','refix,1,2);'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ #013#010+
|
|
|
+ 'procedure TBuildEngine.Log(Level: TVerboseLevel; Msg: String);'#013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' If Assigned(FOnLog) then'#013#010+
|
|
|
+ ' begin'#013#010+
|
|
|
+ ' if Level in [vlInfo,vlDebug] then'#013#010+
|
|
|
+ ' FOnLog(Level,GLogPrefix+Msg)'#013#010+
|
|
|
+ ' else'#013#010+
|
|
|
+ ' FOnLog(L','evel,Msg);'#013#010+
|
|
|
+ ' end;'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ #013#010+
|
|
|
+ 'procedure TBuildEngine.Log(Level: TVerboseLevel; Fmt: String;const Arg'+
|
|
|
+ 's: array of const);'#013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' Log(Level,Format(Fmt,Args));'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ #013#010+
|
|
|
+ 'procedure TBuildEngine.EnterDir(ADir: String);'#013#010+
|
|
|
+ 'Var'#013#010+
|
|
|
+ ' D : String;'#013#010,
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' D:=FStartDir;'#013#010+
|
|
|
+ ' D:=D+ADir;'#013#010+
|
|
|
+ ' Log(vlDebug,SDbgEnterDir,[D]);'#013#010+
|
|
|
+ ' If Not SetCurrentDir(D) then'#013#010+
|
|
|
+ ' Error(SErrChangeDirFailed,[D]);'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ #013#010+
|
|
|
'procedure TBuildEngine.CmdCopyFiles(List: TStrings; Const DestDir: Str'+
|
|
|
- 'ing);'#010+
|
|
|
- #010+
|
|
|
- 'Var'#010+
|
|
|
- ' Args : String;'#010+
|
|
|
- ' I : Integer;'#010+
|
|
|
- ' DestFileName : String;'#010+
|
|
|
- 'begin'#010+
|
|
|
- ' // When the files should be written to an archive, a','dd them'#010+
|
|
|
- ' if assigned(FZipper) then'#010+
|
|
|
- ' begin'#010+
|
|
|
- ' For I:=0 to List.Count-1 do'#010+
|
|
|
- ' if List.Names[i]<>'#039#039' then'#010+
|
|
|
- ' begin'#010+
|
|
|
- ' if IsRelativePath(list.ValueFromIndex[i]) then'#010+
|
|
|
- ' DestFileName:=DestDir+list.ValueFromI','ndex[i]'#010+
|
|
|
- ' else'#010+
|
|
|
- ' DestFileName:=list.ValueFromIndex[i];'#010+
|
|
|
- ' FZipper.Entries.AddFileEntry(List.names[i], DestFileName);'+
|
|
|
- #010+
|
|
|
- ' end'#010+
|
|
|
- ' else'#010+
|
|
|
- ' FZipper.Entries.AddFileEntry(List[i], DestDir+ExtractFi','leN'+
|
|
|
- 'ame(List[i]));'#010+
|
|
|
- ' Exit;'#010+
|
|
|
- ' end;'#010+
|
|
|
- #010+
|
|
|
- ' // Copy the files to their new location on disk'#010+
|
|
|
- ' CmdCreateDir(DestDir);'#010+
|
|
|
- ' If (Defaults.Copy<>'#039#039') then'#010+
|
|
|
- ' begin'#010+
|
|
|
- ' Args:=FileListToString(List,'#039#039');'#010+
|
|
|
- ' Args:=Args+'#039' '#039'+DestDir;'#010+
|
|
|
- ' ExecuteCom','mand(Defaults.Copy,Args);'#010+
|
|
|
- ' end'#010+
|
|
|
- ' else'#010+
|
|
|
- ' For I:=0 to List.Count-1 do'#010+
|
|
|
- ' if List.Names[i]<>'#039#039' then'#010+
|
|
|
- ' begin'#010+
|
|
|
- ' if IsRelativePath(list.ValueFromIndex[i]) then'#010+
|
|
|
- ' DestFileName:=DestDir+list.ValueFromIndex[i]'#010+
|
|
|
- ' ',' else'#010+
|
|
|
- ' DestFileName:=list.ValueFromIndex[i];'#010+
|
|
|
- ' CmdCreateDir(ExtractFilePath(DestFileName));'#010+
|
|
|
- ' SysCopyFile(List.names[i],DestFileName)'#010+
|
|
|
- ' end'#010+
|
|
|
- ' else'#010+
|
|
|
- ' SysCopyFile(List[i],DestDir);'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
- #010+
|
|
|
- 'procedure',' TBuildEngine.CmdCreateDir(const DestDir: String);'#010+
|
|
|
- 'begin'#010+
|
|
|
- ' If (Defaults.MkDir<>'#039#039') then'#010+
|
|
|
- ' ExecuteCommand(Defaults.MkDir,DestDir)'#010+
|
|
|
- ' else'#010+
|
|
|
- ' If not ForceDirectories(DestDir) then'#010+
|
|
|
- ' Error(SErrCreatingDirectory,[DestDir]);'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
- #010+
|
|
|
- 'procedu','re TBuildEngine.CmdMoveFiles(List: TStrings; Const DestDir: S'+
|
|
|
- 'tring);'#010+
|
|
|
- 'Var'#010+
|
|
|
- ' Args : String;'#010+
|
|
|
- ' I : Integer;'#010+
|
|
|
- 'begin'#010+
|
|
|
- ' CmdCreateDir(DestDir);'#010+
|
|
|
- ' If (Defaults.Move<>'#039#039') then'#010+
|
|
|
- ' begin'#010+
|
|
|
- ' Args:=FileListToString(List,'#039#039');'#010+
|
|
|
- ' Args:=Args+'#039' '#039'+Dest','Dir;'#010+
|
|
|
- ' ExecuteCommand(Defaults.Move,Args);'#010+
|
|
|
- ' end'#010+
|
|
|
- ' else'#010+
|
|
|
- ' For I:=0 to List.Count-1 do'#010+
|
|
|
- ' SysMoveFile(List[i],DestDir);'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
- #010+
|
|
|
- 'procedure TBuildEngine.CmdDeleteFiles(List: TStrings);'#010+
|
|
|
- 'Var'#010+
|
|
|
- ' Args : String;'#010+
|
|
|
- ' I : Integer;'#010+
|
|
|
- 'begin'#010+
|
|
|
- ' If (','Defaults.Remove<>'#039#039') then'#010+
|
|
|
- ' begin'#010+
|
|
|
- ' Args:=FileListToString(List,'#039#039');'#010+
|
|
|
- ' ExecuteCommand(Defaults.Remove,Args);'#010+
|
|
|
- ' end'#010+
|
|
|
- ' else'#010+
|
|
|
- ' For I:=0 to List.Count-1 do'#010+
|
|
|
- ' SysDeleteFile(List[i]);'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
- #010+
|
|
|
- 'procedure TBuildEngine.CmdArchiveFile','s(List: TStrings; Const Archive'+
|
|
|
- 'File: String);'#010+
|
|
|
- 'Var'#010+
|
|
|
- ' S,C,O : String;'#010+
|
|
|
- 'begin'#010+
|
|
|
- ' If (Defaults.Archive='#039#039') then'#010+
|
|
|
- ' SysArchiveFiles(List,ArchiveFile)'#010+
|
|
|
- ' else'#010+
|
|
|
- ' begin'#010+
|
|
|
- ' S:=FileListToString(List,'#039#039');'#010+
|
|
|
- ' SplitCommand(Defaults.Archive,C,O);'#010+
|
|
|
- ' ',' If (O='#039#039') then'#010+
|
|
|
- ' O:=ArchiveFile+'#039' '#039'+S'#010+
|
|
|
- ' else'#010+
|
|
|
+ 'ing);'#013#010+
|
|
|
+ #013#010+
|
|
|
+ 'Var'#013#010+
|
|
|
+ ' Arg','s : String;'#013#010+
|
|
|
+ ' I : Integer;'#013#010+
|
|
|
+ ' DestFileName : String;'#013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' // When the files should be written to an archive, add them'#013#010+
|
|
|
+ ' if assigned(FZipper) then'#013#010+
|
|
|
+ ' begin'#013#010+
|
|
|
+ ' For I:=0 to List.Count-1 do'#013#010+
|
|
|
+ ' if List.Names[i]<>'#039#039' then'#013#010+
|
|
|
+ ' ',' begin'#013#010+
|
|
|
+ ' if IsRelativePath(list.ValueFromIndex[i]) then'#013#010+
|
|
|
+ ' DestFileName:=DestDir+list.ValueFromIndex[i]'#013#010+
|
|
|
+ ' else'#013#010+
|
|
|
+ ' DestFileName:=list.ValueFromIndex[i];'#013#010+
|
|
|
+ ' FZipper.Entries.AddFileEn','try(List.names[i], DestFileName'+
|
|
|
+ ');'#013#010+
|
|
|
+ ' end'#013#010+
|
|
|
+ ' else'#013#010+
|
|
|
+ ' FZipper.Entries.AddFileEntry(List[i], DestDir+ExtractFileNam'+
|
|
|
+ 'e(List[i]));'#013#010+
|
|
|
+ ' Exit;'#013#010+
|
|
|
+ ' end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ ' // Copy the files to their new location on disk'#013#010+
|
|
|
+ ' CmdCreateDir(D','estDir);'#013#010+
|
|
|
+ ' If (Defaults.Copy<>'#039#039') then'#013#010+
|
|
|
+ ' begin'#013#010+
|
|
|
+ ' Args:=FileListToString(List,'#039#039');'#013#010+
|
|
|
+ ' Args:=Args+'#039' '#039'+DestDir;'#013#010+
|
|
|
+ ' ExecuteCommand(Defaults.Copy,Args);'#013#010+
|
|
|
+ ' end'#013#010+
|
|
|
+ ' else'#013#010+
|
|
|
+ ' For I:=0 to List.Count-1 do'#013#010+
|
|
|
+ ' if List.Names[i]<>',#039#039' then'#013#010+
|
|
|
+ ' begin'#013#010+
|
|
|
+ ' if IsRelativePath(list.ValueFromIndex[i]) then'#013#010+
|
|
|
+ ' DestFileName:=DestDir+list.ValueFromIndex[i]'#013#010+
|
|
|
+ ' else'#013#010+
|
|
|
+ ' DestFileName:=list.ValueFromIndex[i];'#013#010+
|
|
|
+ ' CmdCreateDir(ExtractFil','ePath(DestFileName));'#013#010+
|
|
|
+ ' SysCopyFile(List.names[i],DestFileName)'#013#010+
|
|
|
+ ' end'#013#010+
|
|
|
+ ' else'#013#010+
|
|
|
+ ' SysCopyFile(List[i],DestDir);'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ #013#010+
|
|
|
+ 'procedure TBuildEngine.CmdCreateDir(const DestDir: String);'#013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' If (Defaults.MkDir<>'#039#039,') then'#013#010+
|
|
|
+ ' ExecuteCommand(Defaults.MkDir,DestDir)'#013#010+
|
|
|
+ ' else'#013#010+
|
|
|
+ ' If not ForceDirectories(DestDir) then'#013#010+
|
|
|
+ ' Error(SErrCreatingDirectory,[DestDir]);'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ #013#010+
|
|
|
+ 'procedure TBuildEngine.CmdMoveFiles(List: TStrings; Const DestDir: Str'+
|
|
|
+ 'ing);'#013#010+
|
|
|
+ 'Var',#013#010+
|
|
|
+ ' Args : String;'#013#010+
|
|
|
+ ' I : Integer;'#013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' CmdCreateDir(DestDir);'#013#010+
|
|
|
+ ' If (Defaults.Move<>'#039#039') then'#013#010+
|
|
|
+ ' begin'#013#010+
|
|
|
+ ' Args:=FileListToString(List,'#039#039');'#013#010+
|
|
|
+ ' Args:=Args+'#039' '#039'+DestDir;'#013#010+
|
|
|
+ ' ExecuteCommand(Defaults.Move,Args);'#013#010+
|
|
|
+ ' end'#013#010+
|
|
|
+ ' else',#013#010+
|
|
|
+ ' For I:=0 to List.Count-1 do'#013#010+
|
|
|
+ ' SysMoveFile(List[i],DestDir);'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ #013#010+
|
|
|
+ 'procedure TBuildEngine.CmdDeleteFiles(List: TStrings);'#013#010+
|
|
|
+ 'Var'#013#010+
|
|
|
+ ' Args : String;'#013#010+
|
|
|
+ ' I : Integer;'#013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' If (Defaults.Remove<>'#039#039') then'#013#010+
|
|
|
+ ' begin'#013#010+
|
|
|
+ ' Args:=','FileListToString(List,'#039#039');'#013#010+
|
|
|
+ ' ExecuteCommand(Defaults.Remove,Args);'#013#010+
|
|
|
+ ' end'#013#010+
|
|
|
+ ' else'#013#010+
|
|
|
+ ' For I:=0 to List.Count-1 do'#013#010+
|
|
|
+ ' SysDeleteFile(List[i]);'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ #013#010+
|
|
|
+ 'procedure TBuildEngine.CmdArchiveFiles(List: TStrings; Const ArchiveFi'+
|
|
|
+ 'le: St','ring);'#013#010+
|
|
|
+ 'Var'#013#010+
|
|
|
+ ' S,C,O : String;'#013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' If (Defaults.Archive='#039#039') then'#013#010+
|
|
|
+ ' SysArchiveFiles(List,ArchiveFile)'#013#010+
|
|
|
+ ' else'#013#010+
|
|
|
+ ' begin'#013#010+
|
|
|
+ ' S:=FileListToString(List,'#039#039');'#013#010+
|
|
|
+ ' SplitCommand(Defaults.Archive,C,O);'#013#010+
|
|
|
+ ' If (O='#039#039') then'#013#010+
|
|
|
+ ' ','O:=ArchiveFile+'#039' '#039'+S'#013#010+
|
|
|
+ ' else'#013#010+
|
|
|
' O:=GlobalDictionary.Substitute(O,['#039'ARCHIVE'#039',ArchiveFil'+
|
|
|
- 'e,'#039'FILESORDIRS'#039']);'#010+
|
|
|
- ' ExecuteCommand(C,O);'#010+
|
|
|
- ' end;'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
- 'procedure TBuildEngine.CmdRenameFile(SourceName, DestName',': String);'#010+
|
|
|
- 'var'#010+
|
|
|
- ' Args: string;'#010+
|
|
|
- 'begin'#010+
|
|
|
- ' If (Defaults.Move<>'#039#039') then'#010+
|
|
|
- ' begin'#010+
|
|
|
- ' Args:=SourceName;'#010+
|
|
|
- ' Args:=Args+'#039' '#039'+DestName;'#010+
|
|
|
- ' ExecuteCommand(Defaults.Move,Args);'#010+
|
|
|
- ' end'#010+
|
|
|
- ' else'#010+
|
|
|
- ' SysMoveFile(SourceName,DestName);'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
- 'procedu','re TBuildEngine.CmdRemoveDirs(List: TStrings);'#010+
|
|
|
- 'Var'#010+
|
|
|
- ' Args : String;'#010+
|
|
|
- ' I : Integer;'#010+
|
|
|
- 'begin'#010+
|
|
|
- ' If (Defaults.RemoveDir<>'#039#039') then'#010+
|
|
|
- ' begin'#010+
|
|
|
- ' Args:=FileListToString(List,'#039#039');'#010+
|
|
|
- ' ExecuteCommand(Defaults.RemoveDir,Args);'#010+
|
|
|
- ' end'#010+
|
|
|
- ' else'#010+
|
|
|
- ' F','or I:=0 to List.Count-1 do'#010+
|
|
|
- ' SysDeleteDirectory(List[i]);'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
- 'procedure TBuildEngine.CmdRemoveTrees(List: TStrings);'#010+
|
|
|
- 'Var'#010+
|
|
|
- ' Args : String;'#010+
|
|
|
- ' I : Integer;'#010+
|
|
|
- 'begin'#010+
|
|
|
- ' If (Defaults.RemoveTree<>'#039#039') then'#010+
|
|
|
- ' begin'#010+
|
|
|
- ' Args:=FileListToString(','List,'#039#039');'#010+
|
|
|
- ' ExecuteCommand(Defaults.RemoveTree,Args);'#010+
|
|
|
- ' end'#010+
|
|
|
- ' else'#010+
|
|
|
- ' For I:=0 to List.Count-1 do'#010+
|
|
|
- ' SysDeleteTree(List[i]);'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
- 'Function TBuildEngine.FileNewer(const Src,Dest : String) : Boolean;'#010+
|
|
|
- #010+
|
|
|
- 'Var'#010+
|
|
|
- ' DS,DD : Longint;'#010+
|
|
|
- ' D1,D2',' : TDateTime;'#010+
|
|
|
- #010+
|
|
|
- 'begin'#010+
|
|
|
- ' DS:=FileAge(Src);'#010+
|
|
|
- ' { Return false if file not found or not accessible }'#010+
|
|
|
- ' if DS=-1 then'#010+
|
|
|
- ' begin'#010+
|
|
|
- ' Log(vlWarning,SWarnCanNotGetFileAge,[Src]);'#010+
|
|
|
- ' Result:=false;'#010+
|
|
|
- ' exit;'#010+
|
|
|
- ' end;'#010+
|
|
|
- ' DD:=FileAge(Dest);'#010+
|
|
|
- ' D1:','=FileDateToDateTime(DS);'#010+
|
|
|
- ' D2:=FileDateToDateTime(DD);'#010+
|
|
|
+ 'e,'#039'FILESORDIRS'#039']);'#013#010+
|
|
|
+ ' ExecuteCommand(C,O);'#013#010+
|
|
|
+ ' end;'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ 'procedure TBuildEngine.CmdRenameFile(SourceName, DestName: String);'#013+
|
|
|
+ #010+
|
|
|
+ 'var'#013#010+
|
|
|
+ ' Ar','gs: string;'#013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' If (Defaults.Move<>'#039#039') then'#013#010+
|
|
|
+ ' begin'#013#010+
|
|
|
+ ' Args:=SourceName;'#013#010+
|
|
|
+ ' Args:=Args+'#039' '#039'+DestName;'#013#010+
|
|
|
+ ' ExecuteCommand(Defaults.Move,Args);'#013#010+
|
|
|
+ ' end'#013#010+
|
|
|
+ ' else'#013#010+
|
|
|
+ ' SysMoveFile(SourceName,DestName);'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ 'procedure TBui','ldEngine.CmdRemoveDirs(List: TStrings);'#013#010+
|
|
|
+ 'Var'#013#010+
|
|
|
+ ' Args : String;'#013#010+
|
|
|
+ ' I : Integer;'#013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' If (Defaults.RemoveDir<>'#039#039') then'#013#010+
|
|
|
+ ' begin'#013#010+
|
|
|
+ ' Args:=FileListToString(List,'#039#039');'#013#010+
|
|
|
+ ' ExecuteCommand(Defaults.RemoveDir,Args);'#013#010+
|
|
|
+ ' end'#013#010+
|
|
|
+ ' else'#013#010+
|
|
|
+ ' ',' For I:=0 to List.Count-1 do'#013#010+
|
|
|
+ ' SysDeleteDirectory(List[i]);'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ 'procedure TBuildEngine.CmdRemoveTrees(List: TStrings);'#013#010+
|
|
|
+ 'Var'#013#010+
|
|
|
+ ' Args : String;'#013#010+
|
|
|
+ ' I : Integer;'#013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' If (Defaults.RemoveTree<>'#039#039') then'#013#010+
|
|
|
+ ' begin'#013#010+
|
|
|
+ ' Args:=Fi','leListToString(List,'#039#039');'#013#010+
|
|
|
+ ' ExecuteCommand(Defaults.RemoveTree,Args);'#013#010+
|
|
|
+ ' end'#013#010+
|
|
|
+ ' else'#013#010+
|
|
|
+ ' For I:=0 to List.Count-1 do'#013#010+
|
|
|
+ ' SysDeleteTree(List[i]);'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ 'Function TBuildEngine.FileNewer(const Src,Dest : String) : Boolean;'#013+
|
|
|
+ #010+
|
|
|
+ #013#010+
|
|
|
+ 'Var'#013#010,
|
|
|
+ ' DS,DD : Longint;'#013#010+
|
|
|
+ ' D1,D2 : TDateTime;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' DS:=FileAge(Src);'#013#010+
|
|
|
+ ' { Return false if file not found or not accessible }'#013#010+
|
|
|
+ ' if DS=-1 then'#013#010+
|
|
|
+ ' begin'#013#010+
|
|
|
+ ' Log(vlWarning,SWarnCanNotGetFileAge,[Src]);'#013#010+
|
|
|
+ ' Result:=false;'#013#010+
|
|
|
+ ' exit;',#013#010+
|
|
|
+ ' end;'#013#010+
|
|
|
+ ' DD:=FileAge(Dest);'#013#010+
|
|
|
+ ' D1:=FileDateToDateTime(DS);'#013#010+
|
|
|
+ ' D2:=FileDateToDateTime(DD);'#013#010+
|
|
|
' Log(vlDebug,SDbgComparingFileTimes,[Src,DateTimeToStr(D1),Dest,DateT'+
|
|
|
- 'imeToStr(D2)]);'#010+
|
|
|
- ' Result:=D1>=D2;'#010+
|
|
|
- ' If Result then'#010+
|
|
|
- ' Log(vlInfo,SInfoSourceNewerDest,[Src,DateTimeToStr(D1),Dest,','Date'+
|
|
|
- 'TimeToStr(D2)]);'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
- #010+
|
|
|
+ 'imeToStr(D2)]);'#013#010+
|
|
|
+ ' Result:=D1>=D2;'#013#010+
|
|
|
+ ' If Result then'#013#010+
|
|
|
+ ' Log(vlInfo,SInfo','SourceNewerDest,[Src,DateTimeToStr(D1),Dest,Date'+
|
|
|
+ 'TimeToStr(D2)]);'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ #013#010+
|
|
|
'procedure TBuildEngine.ExecuteCommands(Commands: TCommands; At: TComma'+
|
|
|
- 'ndAt; APackage: TPackage);'#010+
|
|
|
- 'Var'#010+
|
|
|
- ' C : TCommand;'#010+
|
|
|
- ' I : Integer;'#010+
|
|
|
- ' Cmd,O : String;'#010+
|
|
|
- ' E : Boolean;'#010+
|
|
|
- ' ADictionary: TDictionary;'#010+
|
|
|
- ' SourceFile, DestF','ile: string;'#010+
|
|
|
- 'begin'#010+
|
|
|
- ' For I:=0 to Commands.Count-1 do'#010+
|
|
|
- ' begin'#010+
|
|
|
- ' C:=Commands.CommandItems[i];'#010+
|
|
|
- ' if (C.At=At) then'#010+
|
|
|
- ' begin'#010+
|
|
|
- ' E:=True;'#010+
|
|
|
- #010+
|
|
|
- ' if assigned(APackage) then'#010+
|
|
|
- ' ADictionary := APackage.Dictionary'#010,
|
|
|
- ' else'#010+
|
|
|
- ' ADictionary := GlobalDictionary;'#010+
|
|
|
- ' SourceFile := ADictionary.ReplaceStrings(C.SourceFile);'#010+
|
|
|
- ' DestFile := ADictionary.ReplaceStrings(C.DestFile);'#010+
|
|
|
- ' if IsRelativePath(SourceFile) then'#010+
|
|
|
- ' ',' SourceFile := AddPathPrefix(APackage,SourceFile);'#010+
|
|
|
- ' if IsRelativePath(DestFile) then'#010+
|
|
|
- ' DestFile := AddPathPrefix(APackage,DestFile);'#010+
|
|
|
- #010+
|
|
|
- ' Cmd:=C.Command;'#010+
|
|
|
- ' If (ExtractFilePath(Cmd)='#039#039') then'#010+
|
|
|
- ' C','md:=ExeSearch(Cmd,GetEnvironmentvariable('#039'PATH'#039')'+
|
|
|
- ');'#010+
|
|
|
- #010+
|
|
|
- ' If (SourceFile<>'#039#039') and (DestFile<>'#039#039') then'#010+
|
|
|
- ' begin'#010+
|
|
|
- ' if not FileExists(DestFile) then'#010+
|
|
|
- ' Log(vlInfo,SInfoDestDoesNotExist,[DestFile])'#010+
|
|
|
- ' ',' else'#010+
|
|
|
- ' begin'#010+
|
|
|
- ' E:=FileNewer(SourceFile, DestFile);'#010+
|
|
|
- ' if E and (cmd = '#039#039') then'#010+
|
|
|
- ' begin'#010+
|
|
|
- ' log(vlWarning,SWarnExtCommandNotFound,[C.Command,Des'+
|
|
|
- 'tFile,SourceFile]);',#010+
|
|
|
- ' E := False;'#010+
|
|
|
- ' end;'#010+
|
|
|
- ' end;'#010+
|
|
|
- ' end;'#010+
|
|
|
- ' If E then'#010+
|
|
|
- ' begin'#010+
|
|
|
- ' if Cmd = '#039#039' then'#010+
|
|
|
- ' error(SErrExtCommandNotFound,[C.Command]);'#010+
|
|
|
- #010+
|
|
|
- ' If Assigned','(C.BeforeCommand) then'#010+
|
|
|
- ' C.BeforeCommand(C);'#010+
|
|
|
+ 'ndAt; APackage: TPackage);'#013#010+
|
|
|
+ 'Var'#013#010+
|
|
|
+ ' C : TCommand;'#013#010+
|
|
|
+ ' I : Integer;'#013#010+
|
|
|
+ ' Cmd,O : String;'#013#010+
|
|
|
+ ' E : Boo','lean;'#013#010+
|
|
|
+ ' ADictionary: TDictionary;'#013#010+
|
|
|
+ ' SourceFile, DestFile: string;'#013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' For I:=0 to Commands.Count-1 do'#013#010+
|
|
|
+ ' begin'#013#010+
|
|
|
+ ' C:=Commands.CommandItems[i];'#013#010+
|
|
|
+ ' if (C.At=At) then'#013#010+
|
|
|
+ ' begin'#013#010+
|
|
|
+ ' E:=True;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ ' if assigne','d(APackage) then'#013#010+
|
|
|
+ ' ADictionary := APackage.Dictionary'#013#010+
|
|
|
+ ' else'#013#010+
|
|
|
+ ' ADictionary := GlobalDictionary;'#013#010+
|
|
|
+ ' SourceFile := ADictionary.ReplaceStrings(C.SourceFile);'#013#010+
|
|
|
+ ' DestFile := ADictionary.ReplaceStri','ngs(C.DestFile);'#013#010+
|
|
|
+ ' if IsRelativePath(SourceFile) then'#013#010+
|
|
|
+ ' SourceFile := AddPathPrefix(APackage,SourceFile);'#013#010+
|
|
|
+ ' if IsRelativePath(DestFile) then'#013#010+
|
|
|
+ ' DestFile := AddPathPrefix(APackage,DestFile);'#013#010+
|
|
|
+ #013#010+
|
|
|
+ ' ',' Cmd:=C.Command;'#013#010+
|
|
|
+ ' If (ExtractFilePath(Cmd)='#039#039') then'#013#010+
|
|
|
+ ' Cmd:=ExeSearch(Cmd,GetEnvironmentvariable('#039'PATH'#039'))'+
|
|
|
+ ';'#013#010+
|
|
|
+ #013#010+
|
|
|
+ ' If (SourceFile<>'#039#039') and (DestFile<>'#039#039') then'#013+
|
|
|
+ #010+
|
|
|
+ ' begin'#013#010+
|
|
|
+ ' if not FileExists(De','stFile) then'#013#010+
|
|
|
+ ' Log(vlInfo,SInfoDestDoesNotExist,[DestFile])'#013#010+
|
|
|
+ ' else'#013#010+
|
|
|
+ ' begin'#013#010+
|
|
|
+ ' E:=FileNewer(SourceFile, DestFile);'#013#010+
|
|
|
+ ' if E and (cmd = '#039#039') then'#013#010+
|
|
|
+ ' begin'#013#010+
|
|
|
+ ' ',' log(vlWarning,SWarnExtCommandNotFound,[C.Command,D'+
|
|
|
+ 'estFile,SourceFile]);'#013#010+
|
|
|
+ ' E := False;'#013#010+
|
|
|
+ ' end;'#013#010+
|
|
|
+ ' end;'#013#010+
|
|
|
+ ' end;'#013#010+
|
|
|
+ ' If E then'#013#010+
|
|
|
+ ' begin'#013#010+
|
|
|
+ ' if ','Cmd = '#039#039' then'#013#010+
|
|
|
+ ' error(SErrExtCommandNotFound,[C.Command]);'#013#010+
|
|
|
+ #013#010+
|
|
|
+ ' If Assigned(C.BeforeCommand) then'#013#010+
|
|
|
+ ' C.BeforeCommand(C);'#013#010+
|
|
|
' O:=ADictionary.Substitute(C.CmdLineOptions,['#039'SOURCE'#039+
|
|
|
- ',SourceFile,'#039'DEST'#039',DestFile]);'#010+
|
|
|
- #010+
|
|
|
- ' Log(vlCommand,SInfoExecutingCommand,[Cmd,O]);'#010+
|
|
|
- ' ExecuteCommand(Cm','d,O,nil,C.IgnoreResult);'#010+
|
|
|
- ' If Assigned(C.AfterCommand) then'#010+
|
|
|
- ' C.AfterCommand(C);'#010+
|
|
|
- ' end;'#010+
|
|
|
- ' end;'#010+
|
|
|
- ' end;'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
- #010+
|
|
|
+ ',SourceFile,'#039'DEST'#039',','DestFile]);'#013#010+
|
|
|
+ #013#010+
|
|
|
+ ' Log(vlCommand,SInfoExecutingCommand,[Cmd,O]);'#013#010+
|
|
|
+ ' ExecuteCommand(Cmd,O,nil,C.IgnoreResult);'#013#010+
|
|
|
+ ' If Assigned(C.AfterCommand) then'#013#010+
|
|
|
+ ' C.AfterCommand(C);'#013#010+
|
|
|
+ ' end;'#013#010+
|
|
|
+ ' end;'#013,#010+
|
|
|
+ ' end;'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ #013#010+
|
|
|
'procedure TBuildEngine.LogSearchPath(APackage: TPackage; const ASearch'+
|
|
|
- 'PathName: string; Pat','h: TConditionalStrings; ACPU: TCPU; AOS: TOS);'#010+
|
|
|
- 'var'#010+
|
|
|
- ' S : String;'#010+
|
|
|
- ' I : Integer;'#010+
|
|
|
- ' C : TConditionalString;'#010+
|
|
|
- 'begin'#010+
|
|
|
- ' S:='#039#039';'#010+
|
|
|
- ' for i:=0 to Path.Count-1 do'#010+
|
|
|
- ' begin'#010+
|
|
|
- ' C:=Path[I];'#010+
|
|
|
- ' if (ACPU in C.CPUs) and (AOS in C.OSes) then'#010+
|
|
|
- ' be','gin'#010+
|
|
|
- ' if S<>'#039#039' then'#010+
|
|
|
- ' S:=S+PathSeparator;'#010+
|
|
|
- ' S:=S+APackage.Dictionary.ReplaceStrings(C.Value)'#010+
|
|
|
- ' end;'#010+
|
|
|
- ' end;'#010+
|
|
|
- ' if S<>'#039#039' then'#010+
|
|
|
- ' Log(vlDebug,SDbgSearchPath,[ASearchPathName,S]);'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
- #010+
|
|
|
- 'Function TBuildEngine.F','indFileInPath(APackage: TPackage; Path:TCondi'+
|
|
|
- 'tionalStrings; AFileName:String; var FoundPath:String;ACPU:TCPU;AOS:TO'+
|
|
|
- 'S):Boolean;'#010+
|
|
|
- 'var'#010+
|
|
|
- ' I : Integer;'#010+
|
|
|
- ' C : TConditionalString;'#010+
|
|
|
- 'begin'#010+
|
|
|
- ' Result:=false;'#010+
|
|
|
- ' for i:=0 to Path.Count-1 do'#010+
|
|
|
- ' begin'#010+
|
|
|
- ' ',' C:=Path[I];'#010+
|
|
|
- ' if (ACPU in C.CPUs) and (AOS in C.OSes) then'#010+
|
|
|
- ' begin'#010+
|
|
|
- ' FoundPath:=IncludeTrailingPathDelimiter(APackage.Dictionary.'+
|
|
|
- 'ReplaceStrings(C.Value));'#010+
|
|
|
- ' if FileExists(AddPathPrefix(APackage,FoundPath+AFileName','))'+
|
|
|
- ' then'#010+
|
|
|
- ' begin'#010+
|
|
|
- ' result:=true;'#010+
|
|
|
- ' exit;'#010+
|
|
|
- ' end;'#010+
|
|
|
- ' end;'#010+
|
|
|
- ' end;'#010+
|
|
|
- ' FoundPath:='#039#039';'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
+ 'PathName: string; Path: TConditionalStrings; ACPU: TCPU; AOS: TOS);'#013+
|
|
|
+ #010+
|
|
|
+ 'var'#013#010+
|
|
|
+ ' S : String;'#013#010+
|
|
|
+ ' I : Integer;'#013#010+
|
|
|
+ ' C : TConditionalString;'#013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' S:='#039#039';'#013#010,
|
|
|
+ ' for i:=0 to Path.Count-1 do'#013#010+
|
|
|
+ ' begin'#013#010+
|
|
|
+ ' C:=Path[I];'#013#010+
|
|
|
+ ' if (ACPU in C.CPUs) and (AOS in C.OSes) then'#013#010+
|
|
|
+ ' begin'#013#010+
|
|
|
+ ' if S<>'#039#039' then'#013#010+
|
|
|
+ ' S:=S+PathSeparator;'#013#010+
|
|
|
+ ' S:=S+APackage.Dictionary.ReplaceStrings(C.Va','lue)'#013#010+
|
|
|
+ ' end;'#013#010+
|
|
|
+ ' end;'#013#010+
|
|
|
+ ' if S<>'#039#039' then'#013#010+
|
|
|
+ ' Log(vlDebug,SDbgSearchPath,[ASearchPathName,S]);'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ #013#010+
|
|
|
+ 'Function TBuildEngine.FindFileInPath(APackage: TPackage; Path:TConditi'+
|
|
|
+ 'onalStrings; AFileName:String; var FoundPath:String;ACPU:TC','PU;AOS:TO'+
|
|
|
+ 'S):Boolean;'#013#010+
|
|
|
+ 'var'#013#010+
|
|
|
+ ' I : Integer;'#013#010+
|
|
|
+ ' C : TConditionalString;'#013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' Result:=false;'#013#010+
|
|
|
+ ' for i:=0 to Path.Count-1 do'#013#010+
|
|
|
+ ' begin'#013#010+
|
|
|
+ ' C:=Path[I];'#013#010+
|
|
|
+ ' if (ACPU in C.CPUs) and (AOS in C.OSes) then'#013#010+
|
|
|
+ ' begin'#013#010+
|
|
|
+ ' FoundPa','th:=IncludeTrailingPathDelimiter(APackage.Dictionar'+
|
|
|
+ 'y.ReplaceStrings(C.Value));'#013#010+
|
|
|
+ ' if FileExists(AddPathPrefix(APackage,FoundPath+AFileName)) t'+
|
|
|
+ 'hen'#013#010+
|
|
|
+ ' begin'#013#010+
|
|
|
+ ' result:=true;'#013#010+
|
|
|
+ ' exit;'#013#010+
|
|
|
+ ' end;',#013#010+
|
|
|
+ ' end;'#013#010+
|
|
|
+ ' end;'#013#010+
|
|
|
+ ' FoundPath:='#039#039';'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
'procedure TBuildEngine.GetDirectoriesFromFilelist(const AFileList, ADi'+
|
|
|
- 'rectoryList: TStringList);'#010+
|
|
|
- 'var'#010+
|
|
|
- ' i',': integer;'#010+
|
|
|
- 'begin'#010+
|
|
|
- ' ADirectoryList.Sorted:=true;'#010+
|
|
|
- ' ADirectoryList.Duplicates:=dupIgnore;'#010+
|
|
|
- ' for i := 0 to AFileList.Count-1 do'#010+
|
|
|
- ' ADirectoryList.Add(ExtractFileDir(AFileList.Strings[i]));'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
- #010+
|
|
|
- 'Procedure TBuildEngine.ResolveFileNames(APacka','ge : TPackage; ACPU:TC'+
|
|
|
- 'PU;AOS:TOS;DoChangeDir:boolean=true; WarnIfNotFound:boolean=true);'#010+
|
|
|
- #010+
|
|
|
- ' procedure FindMainSource(T:TTarget);'#010+
|
|
|
- ' var'#010+
|
|
|
- ' SD,SF : String;'#010+
|
|
|
- ' begin'#010+
|
|
|
+ 'rectoryList: TStringList);'#013#010+
|
|
|
+ 'var'#013#010+
|
|
|
+ ' i: integer;'#013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' ADirectoryList.Sorted:=true;'#013#010+
|
|
|
+ ' ADirectoryList.Duplicates:=du','pIgnore;'#013#010+
|
|
|
+ ' for i := 0 to AFileList.Count-1 do'#013#010+
|
|
|
+ ' ADirectoryList.Add(ExtractFileDir(AFileList.Strings[i]));'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ #013#010+
|
|
|
+ 'Procedure TBuildEngine.ResolveFileNames(APackage : TPackage; ACPU:TCPU'+
|
|
|
+ ';AOS:TOS;DoChangeDir:boolean=true; WarnIfNotFound',':boolean=true);'#013+
|
|
|
+ #010+
|
|
|
+ #013#010+
|
|
|
+ ' procedure FindMainSource(T:TTarget);'#013#010+
|
|
|
+ ' var'#013#010+
|
|
|
+ ' SD,SF : String;'#013#010+
|
|
|
+ ' begin'#013#010+
|
|
|
' LogSearchPath(APackage,'#039'package source'#039',APackage.SourcePat'+
|
|
|
- 'h,ACPU,AOS);'#010+
|
|
|
- ' ',' SD:=APackage.Dictionary.ReplaceStrings(T.Directory);'#010+
|
|
|
- ' SF:=APackage.Dictionary.ReplaceStrings(T.SourceFileName);'#010+
|
|
|
- ' if SD='#039#039' then'#010+
|
|
|
- ' FindFileInPath(APackage,APackage.SourcePath,SF,SD,ACPU,AOS);'#010+
|
|
|
- ' if SD<>'#039#039' then'#010+
|
|
|
- ' SD:=IncludeT','railingPathDelimiter(SD);'#010+
|
|
|
- ' T.FTargetSourceFileName:=SD+SF;'#010+
|
|
|
+ 'h,ACPU,AOS);'#013#010+
|
|
|
+ ' SD:=APackage.Dictionary.ReplaceStrings(T.Directory);'#013#010+
|
|
|
+ ' SF:=A','Package.Dictionary.ReplaceStrings(T.SourceFileName);'#013#010+
|
|
|
+ ' if SD='#039#039' then'#013#010+
|
|
|
+ ' FindFileInPath(APackage,APackage.SourcePath,SF,SD,ACPU,AOS);'#013+
|
|
|
+ #010+
|
|
|
+ ' if SD<>'#039#039' then'#013#010+
|
|
|
+ ' SD:=IncludeTrailingPathDelimiter(SD);'#013#010+
|
|
|
+ ' T.FTargetSourceFileName:=SD+SF',';'#013#010+
|
|
|
' if FileExists(AddPathPrefix(APackage,T.TargetSourceFileName)) then'+
|
|
|
- #010+
|
|
|
+ #013#010+
|
|
|
' Log(vlDebug,SDbgResolvedSourceFile,[T.SourceFileName,T.TargetSou'+
|
|
|
- 'rceFileName])'#010+
|
|
|
- ' else'#010+
|
|
|
- ' begin'#010+
|
|
|
- ' ',' if WarnIfNotFound then'#010+
|
|
|
- ' Log(vlWarning,SWarnSourceFileNotFound,[T.SourceFileName,APac'+
|
|
|
- 'kage.Name,MakeTargetString(ACPU,AOS)]);'#010+
|
|
|
- ' APackage.FAllFilesResolved:=false;'#010+
|
|
|
- ' T.FTargetSourceFileName:='#039#039';'#010+
|
|
|
- ' end;'#010+
|
|
|
- ' end;'#010+
|
|
|
- #010+
|
|
|
- ' ','procedure FindIncludeSources(T:TTarget);'#010+
|
|
|
- ' var'#010+
|
|
|
- ' SD,SF : String;'#010+
|
|
|
- ' D : TDependency;'#010+
|
|
|
- ' j : integer;'#010+
|
|
|
- ' begin'#010+
|
|
|
+ 'rceFileName])'#013#010+
|
|
|
+ ' else'#013#010+
|
|
|
+ ' begin'#013#010+
|
|
|
+ ' if WarnIfNotFound then'#013#010+
|
|
|
+ ' Log(vlWarning,S','WarnSourceFileNotFound,[T.SourceFileName,AP'+
|
|
|
+ 'ackage.Name,MakeTargetString(ACPU,AOS)]);'#013#010+
|
|
|
+ ' APackage.FAllFilesResolved:=false;'#013#010+
|
|
|
+ ' T.FTargetSourceFileName:='#039#039';'#013#010+
|
|
|
+ ' end;'#013#010+
|
|
|
+ ' end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ ' procedure FindIncludeSources(T:TTarget);'#013#010+
|
|
|
+ ' var'#013,#010+
|
|
|
+ ' SD,SF : String;'#013#010+
|
|
|
+ ' D : TDependency;'#013#010+
|
|
|
+ ' j : integer;'#013#010+
|
|
|
+ ' begin'#013#010+
|
|
|
' LogSearchPath(APackage,'#039'target include'#039',T.IncludePath,ACPU'+
|
|
|
- ',AOS);'#010+
|
|
|
- ' LogSearchPath(APackage,'#039'package include'#039',APackage.Inc','lud'+
|
|
|
- 'ePath,ACPU,AOS);'#010+
|
|
|
- ' for j:=0 to T.Dependencies.Count-1 do'#010+
|
|
|
- ' begin'#010+
|
|
|
- ' D:=T.Dependencies[j];'#010+
|
|
|
- ' if (D.DependencyType=depInclude) then'#010+
|
|
|
- ' begin'#010+
|
|
|
- ' if D.TargetFileName<>'#039#039' then'#010+
|
|
|
- ' begin'#010+
|
|
|
- ' ',' Exit;'#010+
|
|
|
- ' Log(vlDebug,SDbgSourceAlreadyResolved,[T.Name]);'#010+
|
|
|
- ' end;'#010+
|
|
|
- ' if (ACPU in D.CPUs) and (AOS in D.OSes) then'#010+
|
|
|
- ' begin'#010+
|
|
|
- ' if ExtractFilePath(D.Value)='#039#039' then'#010+
|
|
|
- ' begi','n'#010+
|
|
|
- ' SF:=APAckage.Dictionary.ReplaceStrings(D.Value);'#010+
|
|
|
- ' SD:='#039#039';'#010+
|
|
|
- ' // first check the target specific path'#010+
|
|
|
+ ',AOS);'#013#010+
|
|
|
+ ' LogSearchPath(APackage,'#039'package include'#039',APackage.IncludeP'+
|
|
|
+ 'ath,ACPU,AOS);'#013#010+
|
|
|
+ ' for j:=0 to T.De','pendencies.Count-1 do'#013#010+
|
|
|
+ ' begin'#013#010+
|
|
|
+ ' D:=T.Dependencies[j];'#013#010+
|
|
|
+ ' if (D.DependencyType=depInclude) then'#013#010+
|
|
|
+ ' begin'#013#010+
|
|
|
+ ' if D.TargetFileName<>'#039#039' then'#013#010+
|
|
|
+ ' begin'#013#010+
|
|
|
+ ' Exit;'#013#010+
|
|
|
+ ' Log(vlDebug',',SDbgSourceAlreadyResolved,[T.Name]);'#013#010+
|
|
|
+ ' end;'#013#010+
|
|
|
+ ' if (ACPU in D.CPUs) and (AOS in D.OSes) then'#013#010+
|
|
|
+ ' begin'#013#010+
|
|
|
+ ' if ExtractFilePath(D.Value)='#039#039' then'#013#010+
|
|
|
+ ' begin'#013#010+
|
|
|
+ ' SF:=','APAckage.Dictionary.ReplaceStrings(D.Value);'+
|
|
|
+ #013#010+
|
|
|
+ ' SD:='#039#039';'#013#010+
|
|
|
+ ' // first check the target specific path'#013#010+
|
|
|
' if not FindFileInPath(APackage, T.IncludePath,SF,S'+
|
|
|
- 'D,ACPU,AOS)',' then'#010+
|
|
|
- ' FindFileInPath(APackage, APackage.IncludePath,SF'+
|
|
|
- ',SD,ACPU,AOS);'#010+
|
|
|
- ' if SD<>'#039#039' then'#010+
|
|
|
- ' SD:=IncludeTrailingPathDelimiter(SD);'#010+
|
|
|
- ' D.TargetFileName:=SD+SF;'#010+
|
|
|
- ' ',' end'#010+
|
|
|
- ' else'#010+
|
|
|
- ' D.TargetFileName:=D.Value;'#010+
|
|
|
+ 'D,ACPU,AOS) then'#013#010+
|
|
|
+ ' ',' FindFileInPath(APackage, APackage.IncludePath,'+
|
|
|
+ 'SF,SD,ACPU,AOS);'#013#010+
|
|
|
+ ' if SD<>'#039#039' then'#013#010+
|
|
|
+ ' SD:=IncludeTrailingPathDelimiter(SD);'#013#010+
|
|
|
+ ' D.TargetFileName:=SD+SF;'#013#010+
|
|
|
+ ' end'#013#010+
|
|
|
+ ' ',' else'#013#010+
|
|
|
+ ' D.TargetFileName:=D.Value;'#013#010+
|
|
|
' if FileExists(AddPathPrefix(APackage,D.TargetFileName)'+
|
|
|
- ') then'#010+
|
|
|
+ ') then'#013#010+
|
|
|
' Log(vlDebug,SDbgResolvedIncludeFile,[D.Value,D.Targe'+
|
|
|
- 'tFileName])',#010+
|
|
|
- ' else'#010+
|
|
|
- ' begin'#010+
|
|
|
- ' if WarnIfNotFound then'#010+
|
|
|
+ 'tFileName])'#013#010+
|
|
|
+ ' ',' else'#013#010+
|
|
|
+ ' begin'#013#010+
|
|
|
+ ' if WarnIfNotFound then'#013#010+
|
|
|
' Log(vlWarning,SWarnIncludeFileNotFound,[D.Value,'+
|
|
|
- ' APackage.Name, MakeTargetString(ACPU,AOS)]);'#010+
|
|
|
- ' APackage.FAllFi','lesResolved:=false;'#010+
|
|
|
- ' D.TargetFileName:='#039#039';'#010+
|
|
|
- ' end;'#010+
|
|
|
- ' end;'#010+
|
|
|
- ' end;'#010+
|
|
|
- ' end;'#010+
|
|
|
- ' end;'#010+
|
|
|
- #010+
|
|
|
- ' procedure FindExampleSource(T:TTarget);'#010+
|
|
|
- ' var'#010+
|
|
|
- ' SD,SF : String;'#010+
|
|
|
- ' begin'#010+
|
|
|
- ' LogSearchPath(APackag','e,'#039'package example'#039',APackage.Exampl'+
|
|
|
- 'ePath,ACPU,AOS);'#010+
|
|
|
- ' SD:=APackage.Dictionary.ReplaceStrings(T.Directory);'#010+
|
|
|
- ' SF:=APackage.Dictionary.ReplaceStrings(T.SourceFileName);'#010+
|
|
|
- ' if SD='#039#039' then'#010+
|
|
|
- ' FindFileInPath(APackage, APackage.ExamplePath',',SF,SD,ACPU,AOS);'+
|
|
|
- #010+
|
|
|
- ' if SD<>'#039#039' then'#010+
|
|
|
- ' SD:=IncludeTrailingPathDelimiter(SD);'#010+
|
|
|
- ' T.FTargetSourceFileName:=SD+SF;'#010+
|
|
|
+ ' APackage.Name, MakeTargetString(ACPU,AOS)]);'#013#010+
|
|
|
+ ' APackage.FAllFilesResolv','ed:=false;'#013#010+
|
|
|
+ ' D.TargetFileName:='#039#039';'#013#010+
|
|
|
+ ' end;'#013#010+
|
|
|
+ ' end;'#013#010+
|
|
|
+ ' end;'#013#010+
|
|
|
+ ' end;'#013#010+
|
|
|
+ ' end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ ' procedure FindExampleSource(T:TTarget);'#013#010+
|
|
|
+ ' var'#013#010+
|
|
|
+ ' SD,SF : String;'#013#010+
|
|
|
+ ' begin'#013#010+
|
|
|
+ ' LogSearchPath(APac','kage,'#039'package example'#039',APackage.Exampl'+
|
|
|
+ 'ePath,ACPU,AOS);'#013#010+
|
|
|
+ ' SD:=APackage.Dictionary.ReplaceStrings(T.Directory);'#013#010+
|
|
|
+ ' SF:=APackage.Dictionary.ReplaceStrings(T.SourceFileName);'#013#010+
|
|
|
+ ' if SD='#039#039' then'#013#010+
|
|
|
+ ' FindFileInPath(APackage, APackage.Exam','plePath,SF,SD,ACPU,AOS);'+
|
|
|
+ #013#010+
|
|
|
+ ' if SD<>'#039#039' then'#013#010+
|
|
|
+ ' SD:=IncludeTrailingPathDelimiter(SD);'#013#010+
|
|
|
+ ' T.FTargetSourceFileName:=SD+SF;'#013#010+
|
|
|
' if FileExists(AddPathPrefix(APackage,T.TargetSourceFileName)) then'+
|
|
|
- #010+
|
|
|
- ' Log(vlDebug,SDbgResolvedSourceFile,[T.SourceFi','leName,T.TargetS'+
|
|
|
- 'ourceFileName])'#010+
|
|
|
- ' else'#010+
|
|
|
- ' begin'#010+
|
|
|
- ' if WarnIfNotFound then'#010+
|
|
|
+ #013#010+
|
|
|
+ ' Log(vlDebug,SDbgResolvedSourceFile',',[T.SourceFileName,T.TargetS'+
|
|
|
+ 'ourceFileName])'#013#010+
|
|
|
+ ' else'#013#010+
|
|
|
+ ' begin'#013#010+
|
|
|
+ ' if WarnIfNotFound then'#013#010+
|
|
|
' Log(vlWarning,SWarnSourceFileNotFound,[T.SourceFileName, APa'+
|
|
|
- 'ckage.Name, MakeTargetString(ACPU,AOS)]);'#010+
|
|
|
- ' T.FTargetSourceFileName:='#039#039';'#010+
|
|
|
- ' ',' APackage.FAllFilesResolved:=false;'#010+
|
|
|
- ' end;'#010+
|
|
|
- ' end;'#010+
|
|
|
- #010+
|
|
|
- 'var'#010+
|
|
|
- ' T : TTarget;'#010+
|
|
|
- ' i : Integer;'#010+
|
|
|
- 'begin'#010+
|
|
|
- ' if not((ACPU in APackage.CPUs) and (AOS in APackage.OSes)) then'#010+
|
|
|
- ' exit;'#010+
|
|
|
- ' if APackage.FAllFilesResolved then'#010+
|
|
|
- ' Exit;'#010+
|
|
|
- ' APackage.FAllFilesRe','solved:=true;'#010+
|
|
|
- ' try'#010+
|
|
|
- ' if DoChangeDir and (APackage.Directory<>'#039#039') then'#010+
|
|
|
- ' GPathPrefix := APackage.Directory;'#010+
|
|
|
- ' APackage.Dictionary.AddVariable('#039'CPU'#039',CPUToString(ACPU));'#010+
|
|
|
- ' APackage.Dictionary.AddVariable('#039'OS'#039',OSToString(AOS));'#010+
|
|
|
- ' F','or I:=0 to APackage.Targets.Count-1 do'#010+
|
|
|
- ' begin'#010+
|
|
|
- ' T:=APackage.FTargets.TargetItems[I];'#010+
|
|
|
- ' if (ACPU in T.CPUs) and (AOS in T.OSes) then'#010+
|
|
|
- ' begin'#010+
|
|
|
- ' // Debug information'#010+
|
|
|
- ' Log(vlDebug,SDbgResolvingSourc','esOfTarget,[T.Name,MakeTar'+
|
|
|
- 'getString(ACPU,AOS)]);'#010+
|
|
|
- ' LogIndent;'#010+
|
|
|
- #010+
|
|
|
- ' case T.TargetType of'#010+
|
|
|
- ' ttProgram,'#010+
|
|
|
- ' ttUnit,'#010+
|
|
|
- ' ttImplicitUnit :'#010+
|
|
|
- ' begin'#010+
|
|
|
- ' if T.FTargetSour','ceFileName<>'#039#039' then'#010+
|
|
|
- ' Log(vlDebug,SDbgSourceAlreadyResolved,[T.Name])'#010+
|
|
|
- ' else'#010+
|
|
|
- ' FindMainSource(T);'#010+
|
|
|
- ' if T.Dependencies.Count>0 then'#010+
|
|
|
- ' FindIncludeSources(T)',';'#010+
|
|
|
- ' end;'#010+
|
|
|
- ' ttExampleUnit,'#010+
|
|
|
- ' ttExampleProgram :'#010+
|
|
|
- ' begin'#010+
|
|
|
- ' if T.FTargetSourceFileName<>'#039#039' then'#010+
|
|
|
- ' Log(vlDebug,SDbgSourceAlreadyResolved,[T.Name])'#010+
|
|
|
- ' ',' else'#010+
|
|
|
- ' FindExampleSource(T);'#010+
|
|
|
- ' end;'#010+
|
|
|
- ' end;'#010+
|
|
|
- #010+
|
|
|
- ' LogUnIndent;'#010+
|
|
|
- ' end;'#010+
|
|
|
- ' end;'#010+
|
|
|
- ' finally'#010+
|
|
|
- ' If DoChangeDir and (APackage.Directory<>'#039#039') then'#010+
|
|
|
- ' GPathPrefix := '#039#039';'#010+
|
|
|
- ' end;'#010+
|
|
|
- 'e','nd;'#010+
|
|
|
- #010+
|
|
|
- #010+
|
|
|
- 'function TBuildEngine.GetUnitDir(APackage:TPackage):String;'#010+
|
|
|
- 'begin'#010+
|
|
|
- ' if APackage.UnitDir='#039#039' then'#010+
|
|
|
- ' begin'#010+
|
|
|
- ' // Retrieve Full directory name where to find the units.'#010+
|
|
|
- ' // The search order is:'#010+
|
|
|
- ' // - Package in this fpmake.','pp'#010+
|
|
|
- ' // - LocalUnitDir'#010+
|
|
|
- ' // - GlobalUnitDir'#010+
|
|
|
+ 'ckage.Name, MakeTargetString(ACPU,AOS)]);'#013#010+
|
|
|
+ ' T.FTargetSourceFile','Name:='#039#039';'#013#010+
|
|
|
+ ' APackage.FAllFilesResolved:=false;'#013#010+
|
|
|
+ ' end;'#013#010+
|
|
|
+ ' end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ 'var'#013#010+
|
|
|
+ ' T : TTarget;'#013#010+
|
|
|
+ ' i : Integer;'#013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' if not((ACPU in APackage.CPUs) and (AOS in APackage.OSes)) then'#013#010+
|
|
|
+ ' exit;'#013#010+
|
|
|
+ ' if APackage.FAllFilesResolved then'#013#010+
|
|
|
+ ' ',' Exit;'#013#010+
|
|
|
+ ' APackage.FAllFilesResolved:=true;'#013#010+
|
|
|
+ ' try'#013#010+
|
|
|
+ ' if DoChangeDir and (APackage.Directory<>'#039#039') then'#013#010+
|
|
|
+ ' GPathPrefix := APackage.Directory;'#013#010+
|
|
|
+ ' APackage.Dictionary.AddVariable('#039'CPU'#039',CPUToString(ACPU));'#013+
|
|
|
+ #010+
|
|
|
+ ' APackage.Dictionary.AddVa','riable('#039'OS'#039',OSToString(AOS));'#013+
|
|
|
+ #010+
|
|
|
+ ' For I:=0 to APackage.Targets.Count-1 do'#013#010+
|
|
|
+ ' begin'#013#010+
|
|
|
+ ' T:=APackage.FTargets.TargetItems[I];'#013#010+
|
|
|
+ ' if (ACPU in T.CPUs) and (AOS in T.OSes) then'#013#010+
|
|
|
+ ' begin'#013#010+
|
|
|
+ ' // Debug information'#013#010,
|
|
|
+ ' Log(vlDebug,SDbgResolvingSourcesOfTarget,[T.Name,MakeTarge'+
|
|
|
+ 'tString(ACPU,AOS)]);'#013#010+
|
|
|
+ ' LogIndent;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ ' case T.TargetType of'#013#010+
|
|
|
+ ' ttProgram,'#013#010+
|
|
|
+ ' ttUnit,'#013#010+
|
|
|
+ ' ttImplicitUnit :'#013#010+
|
|
|
+ ' ',' begin'#013#010+
|
|
|
+ ' if T.FTargetSourceFileName<>'#039#039' then'#013#010+
|
|
|
+ ' Log(vlDebug,SDbgSourceAlreadyResolved,[T.Name])'#013+
|
|
|
+ #010+
|
|
|
+ ' else'#013#010+
|
|
|
+ ' FindMainSource(T);'#013#010+
|
|
|
+ ' if T.Dependencies.','Count>0 then'#013#010+
|
|
|
+ ' FindIncludeSources(T);'#013#010+
|
|
|
+ ' end;'#013#010+
|
|
|
+ ' ttExampleUnit,'#013#010+
|
|
|
+ ' ttExampleProgram :'#013#010+
|
|
|
+ ' begin'#013#010+
|
|
|
+ ' if T.FTargetSourceFileName<>'#039#039' then'#013#010+
|
|
|
+ ' ',' Log(vlDebug,SDbgSourceAlreadyResolved,[T.Name])'#013+
|
|
|
+ #010+
|
|
|
+ ' else'#013#010+
|
|
|
+ ' FindExampleSource(T);'#013#010+
|
|
|
+ ' end;'#013#010+
|
|
|
+ ' end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ ' LogUnIndent;'#013#010+
|
|
|
+ ' end;'#013#010+
|
|
|
+ ' end;'#013#010+
|
|
|
+ ' finally'#013#010+
|
|
|
+ ' If DoChange','Dir and (APackage.Directory<>'#039#039') then'#013#010+
|
|
|
+ ' GPathPrefix := '#039#039';'#013#010+
|
|
|
+ ' end;'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ #013#010+
|
|
|
+ 'function TBuildEngine.GetUnitDir(APackage:TPackage):String;'#013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' if APackage.UnitDir='#039#039' then'#013#010+
|
|
|
+ ' begin'#013#010+
|
|
|
+ ' // Retrieve Full directory name where to ','find the units.'#013#010+
|
|
|
+ ' // The search order is:'#013#010+
|
|
|
+ ' // - Package in this fpmake.pp'#013#010+
|
|
|
+ ' // - LocalUnitDir'#013#010+
|
|
|
+ ' // - GlobalUnitDir'#013#010+
|
|
|
' if (APackage.State in [tsCompiled, tsNoCompile, tsInstalled]) th'+
|
|
|
- 'en'#010+
|
|
|
- ' begin'#010+
|
|
|
- ' APackage.UnitDir:=IncludeTrailingPathDelimiter(FStartDir)+In'+
|
|
|
- 'cludeTrailingPathDelimiter(AP','ackage.Directory)+APackage.GetUnitsOutp'+
|
|
|
- 'utDir(Defaults.CPU,Defaults.OS);'#010+
|
|
|
- ' end;'#010+
|
|
|
- ' if (APackage.UnitDir='#039#039') and'#010+
|
|
|
- ' (Defaults.LocalUnitDir<>'#039#039') then'#010+
|
|
|
- ' begin'#010+
|
|
|
- ' APackage.UnitDir:=IncludeTrailingPathDelimiter(Default','s.Lo'+
|
|
|
- 'calUnitDir)+APackage.Name+PathDelim+APackage.GetPackageUnitInstallDir('+
|
|
|
- 'defaults.CPU, Defaults.OS);'#010+
|
|
|
- ' if not SysDirectoryExists(APackage.UnitDir) then'#010+
|
|
|
- ' APackage.UnitDir:='#039#039';'#010+
|
|
|
- ' end;'#010+
|
|
|
- ' if APackage.UnitDir='#039#039' the','n'#010+
|
|
|
- ' begin'#010+
|
|
|
+ 'en'#013#010+
|
|
|
+ ' begin'#013#010+
|
|
|
+ ' A','Package.UnitDir:=IncludeTrailingPathDelimiter(FStartDir)+'+
|
|
|
+ 'IncludeTrailingPathDelimiter(APackage.Directory)+APackage.GetUnitsOutp'+
|
|
|
+ 'utDir(Defaults.CPU,Defaults.OS);'#013#010+
|
|
|
+ ' end;'#013#010+
|
|
|
+ ' if (APackage.UnitDir='#039#039') and'#013#010+
|
|
|
+ ' (Defaults.LocalUnitD','ir<>'#039#039') then'#013#010+
|
|
|
+ ' begin'#013#010+
|
|
|
+ ' APackage.UnitDir:=IncludeTrailingPathDelimiter(Defaults.Loca'+
|
|
|
+ 'lUnitDir)+APackage.Name+PathDelim+APackage.GetPackageUnitInstallDir(de'+
|
|
|
+ 'faults.CPU, Defaults.OS);'#013#010+
|
|
|
+ ' if not SysDirectoryExists(APackage','.UnitDir) then'#013#010+
|
|
|
+ ' APackage.UnitDir:='#039#039';'#013#010+
|
|
|
+ ' end;'#013#010+
|
|
|
+ ' if APackage.UnitDir='#039#039' then'#013#010+
|
|
|
+ ' begin'#013#010+
|
|
|
' APackage.UnitDir:=IncludeTrailingPathDelimiter(Defaults.Glob'+
|
|
|
- 'alUnitDir)+APackage.Name+PathDelim+APackage.GetPackageUnitInstallDir(d'+
|
|
|
- 'efaults.CPU, Defaults.OS);'#010+
|
|
|
- ' if not SysDirectoryExists(APackage.UnitDir) the','n'#010+
|
|
|
- ' APackage.UnitDir:=DirNotFound;'#010+
|
|
|
- ' end;'#010+
|
|
|
- #010+
|
|
|
- ' if (APackage.UnitDir<>DirNotFound) then'#010+
|
|
|
- ' begin'#010+
|
|
|
- ' if FileExists(IncludeTrailingPathDelimiter(APackage.UnitDir)'+
|
|
|
- '+FPMakePPFile) then'#010+
|
|
|
- ' begin'#010+
|
|
|
- ' ',' // The package is not installed, but the source-path i'+
|
|
|
- 's detected.'#010+
|
|
|
- ' // It is an external package so it is impossible to comp'+
|
|
|
- 'ile it, so'#010+
|
|
|
- ' // assume that it has been compiled earlier.'#010+
|
|
|
- ' APackage.UnitDir :=',' IncludeTrailingPathDelimiter(APack'+
|
|
|
- 'age.UnitDir) + APackage.GetUnitsOutputDir(Defaults.CPU,Defaults.OS);'#010+
|
|
|
- ' // If the unit-directory does not exist, you know for su'+
|
|
|
- 're that'#010+
|
|
|
- ' // the package is not compiled'#010+
|
|
|
- ' ',' if not SysDirectoryExists(APackage.UnitDir) then'#010+
|
|
|
- ' APackage.UnitDir:=DirNotFound'#010+
|
|
|
- ' else'#010+
|
|
|
- ' // Set the state to tsNoCompile and not tsCompiled. Be'+
|
|
|
- 'cause packages'#010+
|
|
|
- ' // in the tsCompiled sta','te trigger a rebuild of pack'+
|
|
|
- 'ages that depend'#010+
|
|
|
- ' // on it.'#010+
|
|
|
- ' APackage.FTargetState:=tsNoCompile;'#010+
|
|
|
- ' end'#010+
|
|
|
+ 'alUnitDir)+APackage.Name+PathDelim+APackage.GetPackageU','nitInstallDir'+
|
|
|
+ '(defaults.CPU, Defaults.OS);'#013#010+
|
|
|
+ ' if not SysDirectoryExists(APackage.UnitDir) then'#013#010+
|
|
|
+ ' APackage.UnitDir:=DirNotFound;'#013#010+
|
|
|
+ ' end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ ' if (APackage.UnitDir<>DirNotFound) then'#013#010+
|
|
|
+ ' begin'#013#010+
|
|
|
+ ' if Fi','leExists(IncludeTrailingPathDelimiter(APackage.UnitDi'+
|
|
|
+ 'r)+FPMakePPFile) then'#013#010+
|
|
|
+ ' begin'#013#010+
|
|
|
+ ' // The package is not installed, but the source-path is '+
|
|
|
+ 'detected.'#013#010+
|
|
|
+ ' // It is an external package so it is impossible t','o co'+
|
|
|
+ 'mpile it, so'#013#010+
|
|
|
+ ' // assume that it has been compiled earlier.'#013#010+
|
|
|
+ ' APackage.UnitDir := IncludeTrailingPathDelimiter(APackag'+
|
|
|
+ 'e.UnitDir) + APackage.GetUnitsOutputDir(Defaults.CPU,Defaults.OS);'#013+
|
|
|
+ #010+
|
|
|
+ ' // If the ','unit-directory does not exist, you know for '+
|
|
|
+ 'sure that'#013#010+
|
|
|
+ ' // the package is not compiled'#013#010+
|
|
|
+ ' if not SysDirectoryExists(APackage.UnitDir) then'#013#010+
|
|
|
+ ' APackage.UnitDir:=DirNotFound'#013#010+
|
|
|
+ ' else'#013#010+
|
|
|
+ ' ',' // Set the state to tsNoCompile and not tsCompiled. '+
|
|
|
+ 'Because packages'#013#010+
|
|
|
+ ' // in the tsCompiled state trigger a rebuild of packag'+
|
|
|
+ 'es that depend'#013#010+
|
|
|
+ ' // on it.'#013#010+
|
|
|
+ ' APackage.FTargetState:=tsNoCompil','e;'#013#010+
|
|
|
+ ' end'#013#010+
|
|
|
' else if not (APackage.FTargetState in [tsCompiled, tsNoCompi'+
|
|
|
- 'le]) then'#010+
|
|
|
- ' begin'#010+
|
|
|
- ' ',' APackage.FTargetState:=tsInstalled;'#010+
|
|
|
- ' end;'#010+
|
|
|
- ' end;'#010+
|
|
|
- ' end;'#010+
|
|
|
- #010+
|
|
|
- ' // Special error marker to prevent searches in case of error'#010+
|
|
|
- ' if APackage.UnitDir=DirNotFound then'#010+
|
|
|
- ' Result:='#039#039#010+
|
|
|
- ' else'#010+
|
|
|
- ' Result:=APackage.UnitDir;',#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
- #010+
|
|
|
+ 'le]) then'#013#010+
|
|
|
+ ' begin'#013#010+
|
|
|
+ ' APackage.FTargetState:=tsInstalled;'#013#010+
|
|
|
+ ' end;'#013#010+
|
|
|
+ ' end;'#013#010+
|
|
|
+ ' end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ ' // Special error marke','r to prevent searches in case of error'#013#010+
|
|
|
+ ' if APackage.UnitDir=DirNotFound then'#013#010+
|
|
|
+ ' Result:='#039#039#013#010+
|
|
|
+ ' else'#013#010+
|
|
|
+ ' Result:=APackage.UnitDir;'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ #013#010+
|
|
|
'procedure TBuildEngine.AddDependencyPaths(L: TStrings; DependencyType:'+
|
|
|
- ' TDependencyType; ATarget: TTarget);'#010+
|
|
|
- 'Var'#010+
|
|
|
- ' I : Integer;'#010+
|
|
|
- ' D : TDependency;'#010+
|
|
|
- ' SD : String;'#010+
|
|
|
- 'begin'#010+
|
|
|
- ' For I:=0 to ATarget.Dependencies.Count-1 do'#010+
|
|
|
- ' begin'#010+
|
|
|
- ' D:=A','Target.Dependencies[i];'#010+
|
|
|
- ' if (D.DependencyType=DependencyType) and'#010+
|
|
|
- ' (Defaults.CPU in D.CPUs) and (Defaults.OS in D.OSes) then'#010+
|
|
|
- ' begin'#010+
|
|
|
+ ' TDependencyType; ATarget',': TTarget);'#013#010+
|
|
|
+ 'Var'#013#010+
|
|
|
+ ' I : Integer;'#013#010+
|
|
|
+ ' D : TDependency;'#013#010+
|
|
|
+ ' SD : String;'#013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' For I:=0 to ATarget.Dependencies.Count-1 do'#013#010+
|
|
|
+ ' begin'#013#010+
|
|
|
+ ' D:=ATarget.Dependencies[i];'#013#010+
|
|
|
+ ' if (D.DependencyType=DependencyType) and'#013#010+
|
|
|
+ ' (Defaults.CPU',' in D.CPUs) and (Defaults.OS in D.OSes) then'#013+
|
|
|
+ #010+
|
|
|
+ ' begin'#013#010+
|
|
|
' SD:=ExcludeTrailingPathDelimiter(ExtractFilePath(D.TargetFil'+
|
|
|
- 'eName));'#010+
|
|
|
- ' ',' if SD<>'#039#039' then'#010+
|
|
|
- ' L.Add(SD);'#010+
|
|
|
- ' end;'#010+
|
|
|
- ' end;'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
- #010+
|
|
|
- 'procedure TBuildEngine.AddDependencyUnitPaths(L:TStrings;APackage: TPa'+
|
|
|
- 'ckage);'#010+
|
|
|
- 'Var'#010+
|
|
|
- ' I : Integer;'#010+
|
|
|
- ' P : TPackage;'#010+
|
|
|
- ' D : TDependency;'#010+
|
|
|
- ' S : String;'#010+
|
|
|
- 'begin'#010+
|
|
|
- ' For I:=0 to APacka','ge.Dependencies.Count-1 do'#010+
|
|
|
- ' begin'#010+
|
|
|
- ' D:=APackage.Dependencies[i];'#010+
|
|
|
- ' if (D.DependencyType=depPackage) and'#010+
|
|
|
- ' (Defaults.CPU in D.CPUs) and (Defaults.OS in D.OSes) then'#010+
|
|
|
- ' begin'#010+
|
|
|
- ' P:=TPackage(D.Target);'#010+
|
|
|
- ' I','f Assigned(P) then'#010+
|
|
|
- ' begin'#010+
|
|
|
- ' // Already processed?'#010+
|
|
|
- ' S:=GetUnitDir(P);'#010+
|
|
|
- ' if L.IndexOf(S)=-1 then'#010+
|
|
|
- ' begin'#010+
|
|
|
- ' // Add this package and then dependencies'#010+
|
|
|
- ' ',' L.Add(S);'#010+
|
|
|
- ' AddDependencyUnitPaths(L,P);'#010+
|
|
|
- ' end;'#010+
|
|
|
- ' end;'#010+
|
|
|
- ' end;'#010+
|
|
|
- ' end;'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
+ 'eName));'#013#010+
|
|
|
+ ' if SD<>'#039#039' then'#013#010+
|
|
|
+ ' L.Add(SD);'#013#010+
|
|
|
+ ' end;'#013#010+
|
|
|
+ ' end;'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ #013#010+
|
|
|
+ 'procedure TBuil','dEngine.AddDependencyUnitPaths(L:TStrings;APackage: T'+
|
|
|
+ 'Package);'#013#010+
|
|
|
+ 'Var'#013#010+
|
|
|
+ ' I : Integer;'#013#010+
|
|
|
+ ' P : TPackage;'#013#010+
|
|
|
+ ' D : TDependency;'#013#010+
|
|
|
+ ' S : String;'#013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' For I:=0 to APackage.Dependencies.Count-1 do'#013#010+
|
|
|
+ ' begin'#013#010+
|
|
|
+ ' D:=APackage.Dependencies[i];'#013#010+
|
|
|
+ ' ',' if (D.DependencyType=depPackage) and'#013#010+
|
|
|
+ ' (Defaults.CPU in D.CPUs) and (Defaults.OS in D.OSes) then'#013+
|
|
|
+ #010+
|
|
|
+ ' begin'#013#010+
|
|
|
+ ' P:=TPackage(D.Target);'#013#010+
|
|
|
+ ' If Assigned(P) then'#013#010+
|
|
|
+ ' begin'#013#010+
|
|
|
+ ' // Already proce','ssed?'#013#010+
|
|
|
+ ' S:=GetUnitDir(P);'#013#010+
|
|
|
+ ' if L.IndexOf(S)=-1 then'#013#010+
|
|
|
+ ' begin'#013#010+
|
|
|
+ ' // Add this package and then dependencies'#013#010+
|
|
|
+ ' L.Add(S);'#013#010+
|
|
|
+ ' AddDependencyUnitPaths(L,P);'#013#010,
|
|
|
+ ' end;'#013#010+
|
|
|
+ ' end;'#013#010+
|
|
|
+ ' end;'#013#010+
|
|
|
+ ' end;'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
'function TBuildEngine.AddPathPrefix(APackage: TPackage; APath: string)'+
|
|
|
- ': string;'#010+
|
|
|
- 'begin'#010+
|
|
|
- ' if IsRelativePath(APath) a','nd (GPathPrefix<>'#039#039') then'#010+
|
|
|
- ' result := IncludeTrailingPathDelimiter(GPathPrefix) + APath'#010+
|
|
|
- ' else'#010+
|
|
|
- ' result := APath;'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
- #010+
|
|
|
+ ': string;'#013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' if IsRelativePath(APath) and (GPathPrefix<>'#039#039') then'#013#010+
|
|
|
+ ' result := IncludeTrai','lingPathDelimiter(GPathPrefix) + APath'#013#010+
|
|
|
+ ' else'#013#010+
|
|
|
+ ' result := APath;'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ #013#010+
|
|
|
'Function TBuildEngine.GetCompilerCommand(APackage : TPackage; ATarget '+
|
|
|
- ': TTarget; Env: TStrings) : String;'#010+
|
|
|
- 'Var'#010+
|
|
|
- ' L :',' TUnsortedDuplicatesStringList;'#010+
|
|
|
- ' Args : TStringList;'#010+
|
|
|
- ' s : string;'#010+
|
|
|
- ' i : Integer;'#010+
|
|
|
- 'begin'#010+
|
|
|
- ' if ATarget.TargetSourceFileName = '#039#039' then'#010+
|
|
|
- ' Error(SErrCouldNotCompile,[ATarget.Name, APackage.Name]);'#010+
|
|
|
- #010+
|
|
|
- ' Args:=TStringList.Create;'#010+
|
|
|
- ' Args.Duplicate','s:=dupIgnore;'#010+
|
|
|
- #010+
|
|
|
- ' Result := '#039#039';'#010+
|
|
|
- #010+
|
|
|
- ' //compiler configuration'#010+
|
|
|
- ' if Defaults.NoFPCCfg then'#010+
|
|
|
- ' Args.Add('#039'-n'#039');'#010+
|
|
|
- #010+
|
|
|
- ' // Target OS'#010+
|
|
|
- ' Args.Add('#039'-T'#039'+OSToString(Defaults.OS));'#010+
|
|
|
- #010+
|
|
|
- ' // Target CPU.'#010+
|
|
|
- ' // This setting is only applicable when '#039'fpc'#039' is used a','s c'+
|
|
|
- 'ompiler-executable.'#010+
|
|
|
- ' if ExtractFileName(GetCompiler) = '#039'fpc'#039' then'#010+
|
|
|
- ' Args.Add('#039'-P'#039'+CPUToString(Defaults.CPU));'#010+
|
|
|
- #010+
|
|
|
- ' // Compile mode'#010+
|
|
|
- ' If ATarget.Mode<>cmFPC then'#010+
|
|
|
- ' Args.Add('#039'-M'#039'+ModeToString(ATarget.Mode))'#010+
|
|
|
- ' else If Defaults.Mode<>cmFP','C then'#010+
|
|
|
- ' Args.Add('#039'-M'#039'+ModeToString(Defaults.Mode));'#010+
|
|
|
- ' // Output file paths'#010+
|
|
|
- ' If ATarget.TargetType in ProgramTargets then'#010+
|
|
|
+ ': TTarget; Env: TStrings) : String;'#013#010+
|
|
|
+ 'Var'#013#010+
|
|
|
+ ' L : TUnsortedDuplicatesStringList;'#013#010+
|
|
|
+ ' Args : T','StringList;'#013#010+
|
|
|
+ ' s : string;'#013#010+
|
|
|
+ ' i : Integer;'#013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' if ATarget.TargetSourceFileName = '#039#039' then'#013#010+
|
|
|
+ ' Error(SErrCouldNotCompile,[ATarget.Name, APackage.Name]);'#013#010+
|
|
|
+ #013#010+
|
|
|
+ ' Args:=TStringList.Create;'#013#010+
|
|
|
+ ' Args.Duplicates:=dupIgnore;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ ' Result := '#039#039';'#013#010,
|
|
|
+ #013#010+
|
|
|
+ ' //compiler configuration'#013#010+
|
|
|
+ ' if Defaults.NoFPCCfg then'#013#010+
|
|
|
+ ' Args.Add('#039'-n'#039');'#013#010+
|
|
|
+ #013#010+
|
|
|
+ ' // Target OS'#013#010+
|
|
|
+ ' Args.Add('#039'-T'#039'+OSToString(Defaults.OS));'#013#010+
|
|
|
+ #013#010+
|
|
|
+ ' // Target CPU.'#013#010+
|
|
|
+ ' // This setting is only applicable when '#039'fpc'#039' is used as com'+
|
|
|
+ 'piler-executable.',#013#010+
|
|
|
+ ' if ExtractFileName(GetCompiler) = '#039'fpc'#039' then'#013#010+
|
|
|
+ ' Args.Add('#039'-P'#039'+CPUToString(Defaults.CPU));'#013#010+
|
|
|
+ #013#010+
|
|
|
+ ' // Compile mode'#013#010+
|
|
|
+ ' If ATarget.Mode<>cmFPC then'#013#010+
|
|
|
+ ' Args.Add('#039'-M'#039'+ModeToString(ATarget.Mode))'#013#010+
|
|
|
+ ' else If Defaults.Mode<>cmFPC then'#013#010+
|
|
|
+ ' Arg','s.Add('#039'-M'#039'+ModeToString(Defaults.Mode));'#013#010+
|
|
|
+ ' // Output file paths'#013#010+
|
|
|
+ ' If ATarget.TargetType in ProgramTargets then'#013#010+
|
|
|
' Args.Add('#039'-FE'#039'+AddPathPrefix(APackage,APackage.GetBinOutpu'+
|
|
|
- 'tDir(Defaults.CPU,Defaults.OS)));'#010+
|
|
|
- ' Args.Add('#039'-FU'#039'+Ad','dPathPrefix(APackage,APackage.GetUnitsOut'+
|
|
|
- 'putDir(Defaults.CPU,Defaults.OS)));'#010+
|
|
|
- ' // Object Path'#010+
|
|
|
- ' L:=TUnsortedDuplicatesStringList.Create;'#010+
|
|
|
- ' L.Duplicates:=dupIgnore;'#010+
|
|
|
+ 'tDir(Defaults.CPU,Defaults.OS)));'#013#010+
|
|
|
+ ' Args.Add('#039'-FU'#039'+AddPathPrefi','x(APackage,APackage.GetUnitsOut'+
|
|
|
+ 'putDir(Defaults.CPU,Defaults.OS)));'#013#010+
|
|
|
+ ' // Object Path'#013#010+
|
|
|
+ ' L:=TUnsortedDuplicatesStringList.Create;'#013#010+
|
|
|
+ ' L.Duplicates:=dupIgnore;'#013#010+
|
|
|
' AddConditionalStrings(APackage, L,APackage.ObjectPath,Defaults.CPU,D'+
|
|
|
- 'efault','s.OS);'#010+
|
|
|
+ 'efaults.OS);',#013#010+
|
|
|
' AddConditionalStrings(APackage, L,ATarget.ObjectPath,Defaults.CPU,De'+
|
|
|
- 'faults.OS);'#010+
|
|
|
- ' for i:=0 to L.Count-1 do'#010+
|
|
|
- ' Args.Add('#039'-Fo'#039'+AddPathPrefix(APackage,L[i]));'#010+
|
|
|
- ' FreeAndNil(L);'#010+
|
|
|
- ' // Unit Dirs'#010+
|
|
|
- ' L:=TUnsortedDuplicatesStringList.Create;',#010+
|
|
|
- ' L.Duplicates:=dupIgnore;'#010+
|
|
|
- ' AddDependencyUnitPaths(L,APackage);'#010+
|
|
|
- ' AddDependencyPaths(L,depUnit,ATarget);'#010+
|
|
|
+ 'faults.OS);'#013#010+
|
|
|
+ ' for i:=0 to L.Count-1 do'#013#010+
|
|
|
+ ' Args.Add('#039'-Fo'#039'+AddPathPrefix(APackage,L[i]));'#013#010+
|
|
|
+ ' FreeAndNil(L);'#013#010+
|
|
|
+ ' // Unit Dirs'#013#010+
|
|
|
+ ' L:=TUnsortedDuplicatesStringList.Create;',#013#010+
|
|
|
+ ' L.Duplicates:=dupIgnore;'#013#010+
|
|
|
+ ' AddDependencyUnitPaths(L,APackage);'#013#010+
|
|
|
+ ' AddDependencyPaths(L,depUnit,ATarget);'#013#010+
|
|
|
' AddConditionalStrings(APackage, L,APackage.UnitPath,Defaults.CPU,Def'+
|
|
|
- 'aults.OS);'#010+
|
|
|
- ' AddConditionalStrings(APackage, L,ATarget.UnitPath',',Defaults.CPU,De'+
|
|
|
- 'faults.OS);'#010+
|
|
|
- ' for i:=0 to L.Count-1 do'#010+
|
|
|
- ' Args.Add('#039'-Fu'#039'+AddPathPrefix(APackage,L[i]));'#010+
|
|
|
- ' FreeAndNil(L);'#010+
|
|
|
- ' // Include Path'#010+
|
|
|
- ' L:=TUnsortedDuplicatesStringList.Create;'#010+
|
|
|
- ' L.Duplicates:=dupIgnore;'#010+
|
|
|
- ' AddDependencyPaths(L,depIncl','ude,ATarget);'#010+
|
|
|
+ 'aults.OS);'#013#010+
|
|
|
+ ' AddConditionalStrings(APackage, L,ATarget.Uni','tPath,Defaults.CPU,De'+
|
|
|
+ 'faults.OS);'#013#010+
|
|
|
+ ' for i:=0 to L.Count-1 do'#013#010+
|
|
|
+ ' Args.Add('#039'-Fu'#039'+AddPathPrefix(APackage,L[i]));'#013#010+
|
|
|
+ ' FreeAndNil(L);'#013#010+
|
|
|
+ ' // Include Path'#013#010+
|
|
|
+ ' L:=TUnsortedDuplicatesStringList.Create;'#013#010+
|
|
|
+ ' L.Duplicates:=dupIgnore;'#013#010+
|
|
|
+ ' AddDependencyPat','hs(L,depInclude,ATarget);'#013#010+
|
|
|
' AddConditionalStrings(APackage, L,APackage.IncludePath,Defaults.CPU,'+
|
|
|
- 'Defaults.OS);'#010+
|
|
|
+ 'Defaults.OS);'#013#010+
|
|
|
' AddConditionalStrings(APackage, L,ATarget.IncludePath,Defaults.CPU,D'+
|
|
|
- 'efaults.OS);'#010+
|
|
|
- ' for i:=0 to L.Count-1 do'#010+
|
|
|
- ' Args.Add('#039'-Fi'#039'+AddPathPrefix','(APackage,L[i]));'#010+
|
|
|
- ' FreeAndNil(L);'#010+
|
|
|
- ' // Custom Options'#010+
|
|
|
- ' If (Defaults.HaveOptions) then'#010+
|
|
|
- ' Args.AddStrings(Defaults.Options);'#010+
|
|
|
- #010+
|
|
|
- ' APackage.ApplyPackageVariantToCompilerOptions(Args);'#010+
|
|
|
- #010+
|
|
|
- ' If (APackage.HaveOptions) then'#010+
|
|
|
- ' Args.AddStrings(APa','ckage.Options);'#010+
|
|
|
- ' If (ATarget.HaveOptions) then'#010+
|
|
|
- ' Args.AddStrings(ATarget.Options);'#010+
|
|
|
- #010+
|
|
|
- ' {$ifdef HAS_UNIT_PROCESS}'#010+
|
|
|
- ' // Force the compiler-output to be easy parseable'#010+
|
|
|
- ' if not Verbose then'#010+
|
|
|
- ' args.Add('#039'-viq'#039');'#010+
|
|
|
- ' {$endif}'#010+
|
|
|
- #010+
|
|
|
- ' // Convert to s','tring'#010+
|
|
|
- ' Result:='#039#039';'#010+
|
|
|
- ' for i:=0 to Args.Count-1 do'#010+
|
|
|
- ' Result:=Result+'#039' '#039'+maybequoted(Args[i]);'#010+
|
|
|
- ' Delete(result,1,1);'#010+
|
|
|
- #010+
|
|
|
- ' if Defaults.UseEnvironment and assigned(Env) then'#010+
|
|
|
- ' begin'#010+
|
|
|
- ' env.Values['#039'FPCEXTCMD'#039'] := Result;'#010+
|
|
|
- ' result := '#039'!F','PCEXTCMD'#039';'#010+
|
|
|
+ 'efaults.OS);'#013#010+
|
|
|
+ ' for i:=0 to L.Count-1 do'#013#010+
|
|
|
+ ' Args.Add('#039'-F','i'#039'+AddPathPrefix(APackage,L[i]));'#013#010+
|
|
|
+ ' FreeAndNil(L);'#013#010+
|
|
|
+ ' // Custom Options'#013#010+
|
|
|
+ ' If (Defaults.HaveOptions) then'#013#010+
|
|
|
+ ' Args.AddStrings(Defaults.Options);'#013#010+
|
|
|
+ #013#010+
|
|
|
+ ' APackage.ApplyPackageVariantToCompilerOptions(Args);'#013#010+
|
|
|
+ #013#010+
|
|
|
+ ' If (APackage.HaveOptions) then',#013#010+
|
|
|
+ ' Args.AddStrings(APackage.Options);'#013#010+
|
|
|
+ ' If (ATarget.HaveOptions) then'#013#010+
|
|
|
+ ' Args.AddStrings(ATarget.Options);'#013#010+
|
|
|
+ #013#010+
|
|
|
+ ' {$ifdef HAS_UNIT_PROCESS}'#013#010+
|
|
|
+ ' // Force the compiler-output to be easy parseable'#013#010+
|
|
|
+ ' if not Verbose then'#013#010+
|
|
|
+ ' args.Add('#039'-viq'#039,');'#013#010+
|
|
|
+ ' {$endif}'#013#010+
|
|
|
+ #013#010+
|
|
|
+ ' // Convert to string'#013#010+
|
|
|
+ ' Result:='#039#039';'#013#010+
|
|
|
+ ' for i:=0 to Args.Count-1 do'#013#010+
|
|
|
+ ' Result:=Result+'#039' '#039'+maybequoted(Args[i]);'#013#010+
|
|
|
+ ' Delete(result,1,1);'#013#010+
|
|
|
+ #013#010+
|
|
|
+ ' if Defaults.UseEnvironment and assigned(Env) then'#013#010+
|
|
|
+ ' begin'#013#010+
|
|
|
+ ' env.Values[',#039'FPCEXTCMD'#039'] := Result;'#013#010+
|
|
|
+ ' result := '#039'!FPCEXTCMD'#039';'#013#010+
|
|
|
' // Make sure that this process'#039' environment variables are pa'+
|
|
|
- 'ssed to the'#010+
|
|
|
- ' // compiler'#039's environment'#010+
|
|
|
- ' for i := 0 to GetEnvironmentVariableCount-1 do'#010+
|
|
|
- ' env.Add(GetEnvironmentString(i));'#010+
|
|
|
- ' end;'#010+
|
|
|
- #010+
|
|
|
- ' // Add Filen','ame to compile'#010+
|
|
|
+ 'ssed to the'#013#010+
|
|
|
+ ' // compiler'#039's environment'#013#010+
|
|
|
+ ' for i := 0 to GetEnvironmentVariableCount-1 do'#013#010+
|
|
|
+ ' env.Add(Ge','tEnvironmentString(i));'#013#010+
|
|
|
+ ' end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ ' // Add Filename to compile'#013#010+
|
|
|
' result := result + '#039' '#039' + AddPathPrefix(APackage,ATarget.Targ'+
|
|
|
- 'etSourceFileName);'#010+
|
|
|
- #010+
|
|
|
- ' Args.Free;'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
- #010+
|
|
|
- 'Function TBuildEngine.GetCompiler : String;'#010+
|
|
|
- 'Var'#010+
|
|
|
- ' S : String;'#010+
|
|
|
- 'begin'#010+
|
|
|
- ' // Cache in FCompiler for speed.'#010+
|
|
|
- ' If (FCompiler='#039#039') ','then'#010+
|
|
|
- ' begin'#010+
|
|
|
- ' FCompiler:=Defaults.Compiler;'#010+
|
|
|
- ' If (ExtractFilePath(FCompiler)='#039#039') then'#010+
|
|
|
- ' begin'#010+
|
|
|
- ' S:=ExeSearch(FCompiler,GetEnvironmentVariable('#039'PATH'#039'));'#010+
|
|
|
- ' If (S<>'#039#039') then'#010+
|
|
|
- ' FCompiler:=S;'#010+
|
|
|
- ' end;'#010+
|
|
|
- ' end;'#010+
|
|
|
- ' Result',':=FCompiler;'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
- #010+
|
|
|
- 'procedure TBuildEngine.CreateOutputDir(APackage: TPackage);'#010+
|
|
|
- 'Var'#010+
|
|
|
- ' D : String;'#010+
|
|
|
- ' i: integer;'#010+
|
|
|
- 'begin'#010+
|
|
|
- ' //create a units directory'#010+
|
|
|
- ' D:=AddPathPrefix(APackage,APackage.GetUnitsOutputDir(Defaults.CPU,De'+
|
|
|
- 'faults.OS));'#010+
|
|
|
- ' If not S','ysDirectoryExists(D) then'#010+
|
|
|
- ' begin'#010+
|
|
|
- ' Log(vlInfo,SInfoCreatingOutputDir,[D]);'#010+
|
|
|
- ' CmdCreateDir(D);'#010+
|
|
|
- ' end;'#010+
|
|
|
- #010+
|
|
|
- ' //also create a bin directory for programtargets'#010+
|
|
|
- ' For i := 0 to Pred(APackage.Targets.Count) do'#010+
|
|
|
- ' begin'#010+
|
|
|
- ' if APackag','e.Targets.TargetItems[i].TargetType in (ProgramTarge'+
|
|
|
- 'ts-[ttExampleProgram]) then'#010+
|
|
|
- ' begin'#010+
|
|
|
- ' D:=AddPathPrefix(APackage,APackage.GetBinOutputDir(Defaults.'+
|
|
|
- 'CPU,Defaults.OS));'#010+
|
|
|
- ' If not SysDirectoryExists(D) then'#010+
|
|
|
- ' b','egin'#010+
|
|
|
- ' Log(vlInfo,SInfoCreatingOutputDir,[D]);'#010+
|
|
|
- ' CmdCreateDir(D);'#010+
|
|
|
- ' end;'#010+
|
|
|
- ' //do not continue loop, directory is made anyway'#010+
|
|
|
- ' break;'#010+
|
|
|
- ' end;'#010+
|
|
|
- ' end;'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
- #010+
|
|
|
- 'Function TBuildEngine.Depend','encyOK(ADependency : TDependency) : Bool'+
|
|
|
- 'ean;'#010+
|
|
|
- 'begin'#010+
|
|
|
+ 'etSourceFileName);'#013#010+
|
|
|
+ #013#010+
|
|
|
+ ' Args.Free;'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ #013#010+
|
|
|
+ 'Function TBuildEngine.GetCompiler : String;'#013#010+
|
|
|
+ 'Var'#013#010+
|
|
|
+ ' S : String;'#013#010,
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' // Cache in FCompiler for speed.'#013#010+
|
|
|
+ ' If (FCompiler='#039#039') then'#013#010+
|
|
|
+ ' begin'#013#010+
|
|
|
+ ' FCompiler:=Defaults.Compiler;'#013#010+
|
|
|
+ ' If (ExtractFilePath(FCompiler)='#039#039') then'#013#010+
|
|
|
+ ' begin'#013#010+
|
|
|
+ ' S:=ExeSearch(FCompiler,GetEnvironmentVariable('#039'PATH'#039'));'#013+
|
|
|
+ #010+
|
|
|
+ ' ',' If (S<>'#039#039') then'#013#010+
|
|
|
+ ' FCompiler:=S;'#013#010+
|
|
|
+ ' end;'#013#010+
|
|
|
+ ' end;'#013#010+
|
|
|
+ ' Result:=FCompiler;'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ #013#010+
|
|
|
+ 'procedure TBuildEngine.CreateOutputDir(APackage: TPackage);'#013#010+
|
|
|
+ 'Var'#013#010+
|
|
|
+ ' D : String;'#013#010+
|
|
|
+ ' i: integer;'#013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' //create a units directory'#013#010+
|
|
|
+ ' D:=AddPa','thPrefix(APackage,APackage.GetUnitsOutputDir(Defaults.CPU,'+
|
|
|
+ 'Defaults.OS));'#013#010+
|
|
|
+ ' If not SysDirectoryExists(D) then'#013#010+
|
|
|
+ ' begin'#013#010+
|
|
|
+ ' Log(vlInfo,SInfoCreatingOutputDir,[D]);'#013#010+
|
|
|
+ ' CmdCreateDir(D);'#013#010+
|
|
|
+ ' end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ ' //also create a bin directory for',' programtargets'#013#010+
|
|
|
+ ' For i := 0 to Pred(APackage.Targets.Count) do'#013#010+
|
|
|
+ ' begin'#013#010+
|
|
|
+ ' if APackage.Targets.TargetItems[i].TargetType in (ProgramTargets'+
|
|
|
+ '-[ttExampleProgram]) then'#013#010+
|
|
|
+ ' begin'#013#010+
|
|
|
+ ' D:=AddPathPrefix(APackage,APackage.GetBin','OutputDir(Default'+
|
|
|
+ 's.CPU,Defaults.OS));'#013#010+
|
|
|
+ ' If not SysDirectoryExists(D) then'#013#010+
|
|
|
+ ' begin'#013#010+
|
|
|
+ ' Log(vlInfo,SInfoCreatingOutputDir,[D]);'#013#010+
|
|
|
+ ' CmdCreateDir(D);'#013#010+
|
|
|
+ ' end;'#013#010+
|
|
|
+ ' //do not continue loop',', directory is made anyway'#013#010+
|
|
|
+ ' break;'#013#010+
|
|
|
+ ' end;'#013#010+
|
|
|
+ ' end;'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ #013#010+
|
|
|
+ 'Function TBuildEngine.DependencyOK(ADependency : TDependency) : Boolea'+
|
|
|
+ 'n;'#013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
' Result:=(Defaults.CPU in ADependency.CPUs) and (Defaults.OS in ADepe'+
|
|
|
- 'ndency.OSes);'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
+ 'ndency.OS','es);'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
'function TBuildEngine.TargetOK(ATarget: TTarget; ACPU: TCPU; AOS: TOS)'+
|
|
|
- ': Boolean;'#010+
|
|
|
- 'begin'#010+
|
|
|
- ' if Default','s.SkipCrossPrograms and'#010+
|
|
|
- ' (ATarget.TargetType in ProgramTargets) and'#010+
|
|
|
- ' IsDifferentFromBuild(ACPU, AOS) then'#010+
|
|
|
- ' result := False'#010+
|
|
|
- ' else'#010+
|
|
|
- ' Result:=(ACPU in ATarget.CPUs) and (AOS in ATarget.OSes);'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
- 'function TBuildEngine.TargetIns','tallOK(ATarget: TTarget; ACPU: TCPU; '+
|
|
|
- 'AOS: TOS): Boolean;'#010+
|
|
|
- 'begin'#010+
|
|
|
- ' result := TargetOK(ATarget, ACPU, AOS) and ATarget.Install;'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
- #010+
|
|
|
- 'Function TBuildEngine.PackageOK(APackage : TPackage) : Boolean;'#010+
|
|
|
- 'begin'#010+
|
|
|
- ' Result:=(Defaults.CPU in APackage.CP','Us) and (Defaults.OS in APacka'+
|
|
|
- 'ge.OSes);'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
- #010+
|
|
|
- 'procedure TBuildEngine.DoBeforeCompile(APackage: TPackage);'#010+
|
|
|
- 'begin'#010+
|
|
|
- ' ExecuteCommands(APackage.Commands,caBeforeCompile);'#010+
|
|
|
- ' If Assigned(APackage.BeforeCompile) then'#010+
|
|
|
- ' APackage.BeforeCompile(APa','ckage);'#010+
|
|
|
- ' If Assigned(APackage.BeforeCompileProc) then'#010+
|
|
|
- ' APackage.BeforeCompileProc(APackage);'#010+
|
|
|
- ' // It could be that files that weren'#039't found before are availabl'+
|
|
|
- 'e now.'#010+
|
|
|
- ' ResolveFileNames(APackage,Defaults.CPU,Defaults.OS,false,true);'#010+
|
|
|
- 'end;',#010+
|
|
|
- #010+
|
|
|
- #010+
|
|
|
- 'procedure TBuildEngine.DoAfterCompile(APackage: TPackage);'#010+
|
|
|
- 'begin'#010+
|
|
|
- ' If Assigned(APackage.AfterCompile) then'#010+
|
|
|
- ' APackage.AfterCompile(APackage);'#010+
|
|
|
- ' If Assigned(APackage.AfterCompileProc) then'#010+
|
|
|
- ' APackage.AfterCompileProc(APackage);'#010+
|
|
|
- ' Exec','uteCommands(APackage.Commands,caAfterCompile);'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
- #010+
|
|
|
- 'Function TBuildEngine.NeedsCompile(APackage:TPackage;ATarget: TTarget)'+
|
|
|
- ': Boolean;'#010+
|
|
|
- 'Var'#010+
|
|
|
- ' I : Integer;'#010+
|
|
|
- ' D : TDependency;'#010+
|
|
|
- ' T : TTarget;'#010+
|
|
|
- ' OD,OFN,TFN : String;'#010+
|
|
|
- ' CompileReason: String;'#010+
|
|
|
- 'begi','n'#010+
|
|
|
- ' Result:=False;'#010+
|
|
|
- #010+
|
|
|
- ' // Forced recompile?'#010+
|
|
|
- ' if FForceCompile then'#010+
|
|
|
- ' begin'#010+
|
|
|
- ' Result:=true;'#010+
|
|
|
- ' CompileReason:=SDbgForcedCompile;'#010+
|
|
|
- ' end;'#010+
|
|
|
- #010+
|
|
|
- ' // For now examples are not compiled at all'#010+
|
|
|
- ' if ATarget.TargetType in [ttExampleUnit, ttExampl','eProgram] then'#010+
|
|
|
- ' Exit;'#010+
|
|
|
- #010+
|
|
|
- ' // Files which should not be compiled on this target can not trigger'+
|
|
|
- ' a compile.'#010+
|
|
|
- ' if not TargetOK(ATarget, Defaults.CPU, Defaults.OS) then'#010+
|
|
|
- ' Exit;'#010+
|
|
|
- #010+
|
|
|
- ' // Check output file'#010+
|
|
|
- ' if not result then'#010+
|
|
|
- ' begin'#010+
|
|
|
- ' if',' ATarget.TargetType in ProgramTargets then'#010+
|
|
|
- ' OD:=APackage.GetBinOutputDir(Defaults.CPU,Defaults.OS)'#010+
|
|
|
- ' else'#010+
|
|
|
- ' OD:=APackage.GetUnitsOutputDir(Defaults.CPU,Defaults.OS);'#010+
|
|
|
- ' If (OD<>'#039#039') then'#010+
|
|
|
- ' OD:=IncludeTrailingPathDel','imiter(OD);'#010+
|
|
|
- ' OFN:=AddPathPrefix(APackage, OD+ATarget.GetOutPutFileName(Defaul'+
|
|
|
- 'ts.OS));'#010+
|
|
|
- ' Result:=Not FileExists(OFN);'#010+
|
|
|
- ' if Result then'#010+
|
|
|
- ' begin'#010+
|
|
|
- ' CompileReason:=SDbgOutputDoesNotExist;'#010+
|
|
|
- ' Log(vlDebug,SDbgOutputNo','tYetAvailable,[OFN]);'#010+
|
|
|
- ' end;'#010+
|
|
|
- ' end;'#010+
|
|
|
- #010+
|
|
|
- ' // Check main source'#010+
|
|
|
- ' If not Result then'#010+
|
|
|
- ' begin'#010+
|
|
|
- ' TFN := AddPathPrefix(APackage,ATarget.TargetSourceFileName);'#010+
|
|
|
- ' if FileExists(TFN) then'#010+
|
|
|
- ' Result:=FileNewer(TFN,OFN);'#010+
|
|
|
- ' if',' Result then'#010+
|
|
|
- ' CompileReason:=SDbgNewerSource;'#010+
|
|
|
- ' end;'#010+
|
|
|
- #010+
|
|
|
- ' // Check unit and include dependencies'#010+
|
|
|
- ' If not Result then'#010+
|
|
|
- ' begin'#010+
|
|
|
+ ': Boolean;'#013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' if Defaults.SkipCrossPrograms and'#013#010+
|
|
|
+ ' (ATarget.TargetType in ProgramTargets) and'#013#010+
|
|
|
+ ' IsDifferentFromBuild(ACPU, AOS) then'#013#010+
|
|
|
+ ' resu','lt := False'#013#010+
|
|
|
+ ' else'#013#010+
|
|
|
+ ' Result:=(ACPU in ATarget.CPUs) and (AOS in ATarget.OSes);'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ 'function TBuildEngine.TargetInstallOK(ATarget: TTarget; ACPU: TCPU; AO'+
|
|
|
+ 'S: TOS): Boolean;'#013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' result := TargetOK(ATarget, ACPU, AOS) and ATarget','.Install;'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ #013#010+
|
|
|
+ 'Function TBuildEngine.PackageOK(APackage : TPackage) : Boolean;'#013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' Result:=(Defaults.CPU in APackage.CPUs) and (Defaults.OS in APackage'+
|
|
|
+ '.OSes);'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ #013#010+
|
|
|
+ 'procedure TBuildEngine.DoBeforeCompile(APackage: TPackage)',';'#013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' ExecuteCommands(APackage.Commands,caBeforeCompile);'#013#010+
|
|
|
+ ' If Assigned(APackage.BeforeCompile) then'#013#010+
|
|
|
+ ' APackage.BeforeCompile(APackage);'#013#010+
|
|
|
+ ' If Assigned(APackage.BeforeCompileProc) then'#013#010+
|
|
|
+ ' APackage.BeforeCompileProc(APackage);'#013#010+
|
|
|
+ ' ',' // It could be that files that weren'#039't found before are availa'+
|
|
|
+ 'ble now.'#013#010+
|
|
|
+ ' ResolveFileNames(APackage,Defaults.CPU,Defaults.OS,false,true);'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ #013#010+
|
|
|
+ 'procedure TBuildEngine.DoAfterCompile(APackage: TPackage);'#013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' If Assigned(APackage.','AfterCompile) then'#013#010+
|
|
|
+ ' APackage.AfterCompile(APackage);'#013#010+
|
|
|
+ ' If Assigned(APackage.AfterCompileProc) then'#013#010+
|
|
|
+ ' APackage.AfterCompileProc(APackage);'#013#010+
|
|
|
+ ' ExecuteCommands(APackage.Commands,caAfterCompile);'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ #013#010+
|
|
|
+ 'Function TBuildEngine.NeedsCo','mpile(APackage:TPackage;ATarget: TTarge'+
|
|
|
+ 't): Boolean;'#013#010+
|
|
|
+ 'Var'#013#010+
|
|
|
+ ' I : Integer;'#013#010+
|
|
|
+ ' D : TDependency;'#013#010+
|
|
|
+ ' T : TTarget;'#013#010+
|
|
|
+ ' OD,OFN,TFN : String;'#013#010+
|
|
|
+ ' CompileReason: String;'#013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' Result:=False;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ ' // Forced recompile?'#013#010+
|
|
|
+ ' if FForceCompile then'#013#010+
|
|
|
+ ' ','begin'#013#010+
|
|
|
+ ' Result:=true;'#013#010+
|
|
|
+ ' CompileReason:=SDbgForcedCompile;'#013#010+
|
|
|
+ ' end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ ' // For now examples are not compiled at all'#013#010+
|
|
|
+ ' if ATarget.TargetType in [ttExampleUnit, ttExampleProgram] then'#013#010+
|
|
|
+ ' Exit;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ ' // Files which should not be compi','led on this target can not trigg'+
|
|
|
+ 'er a compile.'#013#010+
|
|
|
+ ' if not TargetOK(ATarget, Defaults.CPU, Defaults.OS) then'#013#010+
|
|
|
+ ' Exit;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ ' // Check output file'#013#010+
|
|
|
+ ' if not result then'#013#010+
|
|
|
+ ' begin'#013#010+
|
|
|
+ ' if ATarget.TargetType in ProgramTargets then'#013#010+
|
|
|
+ ' OD:','=APackage.GetBinOutputDir(Defaults.CPU,Defaults.OS)'#013#010+
|
|
|
+ ' else'#013#010+
|
|
|
+ ' OD:=APackage.GetUnitsOutputDir(Defaults.CPU,Defaults.OS);'#013#010+
|
|
|
+ ' If (OD<>'#039#039') then'#013#010+
|
|
|
+ ' OD:=IncludeTrailingPathDelimiter(OD);'#013#010+
|
|
|
+ ' OFN:=AddPathPrefix(APackage, OD','+ATarget.GetOutPutFileName(Defa'+
|
|
|
+ 'ults.OS));'#013#010+
|
|
|
+ ' Result:=Not FileExists(OFN);'#013#010+
|
|
|
+ ' if Result then'#013#010+
|
|
|
+ ' begin'#013#010+
|
|
|
+ ' CompileReason:=SDbgOutputDoesNotExist;'#013#010+
|
|
|
+ ' Log(vlDebug,SDbgOutputNotYetAvailable,[OFN]);'#013#010+
|
|
|
+ ' end;'#013#010+
|
|
|
+ ' end',';'#013#010+
|
|
|
+ #013#010+
|
|
|
+ ' // Check main source'#013#010+
|
|
|
+ ' If not Result then'#013#010+
|
|
|
+ ' begin'#013#010+
|
|
|
+ ' TFN := AddPathPrefix(APackage,ATarget.TargetSourceFileName);'#013+
|
|
|
+ #010+
|
|
|
+ ' if FileExists(TFN) then'#013#010+
|
|
|
+ ' Result:=FileNewer(TFN,OFN);'#013#010+
|
|
|
+ ' if Result then'#013#010+
|
|
|
+ ' CompileReaso','n:=SDbgNewerSource;'#013#010+
|
|
|
+ ' end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ ' // Check unit and include dependencies'#013#010+
|
|
|
+ ' If not Result then'#013#010+
|
|
|
+ ' begin'#013#010+
|
|
|
' ResolveDependencies(ATarget.Dependencies,ATarget.Collection as T'+
|
|
|
- 'Targets);'#010+
|
|
|
- ' I:=0;'#010+
|
|
|
- ' for i:=','0 to ATarget.Dependencies.Count-1 do'#010+
|
|
|
- ' begin'#010+
|
|
|
- ' D:=ATarget.Dependencies[i];'#010+
|
|
|
+ 'Targets);'#013#010+
|
|
|
+ ' I:=0;'#013#010+
|
|
|
+ ' for i:=0 to ATarget.Dependencies','.Count-1 do'#013#010+
|
|
|
+ ' begin'#013#010+
|
|
|
+ ' D:=ATarget.Dependencies[i];'#013#010+
|
|
|
' if (Defaults.CPU in D.CPUs) and (Defaults.OS in D.OSes) then'+
|
|
|
- #010+
|
|
|
- ' begin'#010+
|
|
|
- ' case D.DependencyType of'#010+
|
|
|
- ' depUnit',' :'#010+
|
|
|
- ' begin'#010+
|
|
|
- ' T:=TTarget(D.Target);'#010+
|
|
|
- ' If (T=Nil) then'#010+
|
|
|
+ #013#010+
|
|
|
+ ' begin'#013#010+
|
|
|
+ ' case D.DependencyType of'#013#010+
|
|
|
+ ' depUnit :'#013#010+
|
|
|
+ ' ',' begin'#013#010+
|
|
|
+ ' T:=TTarget(D.Target);'#013#010+
|
|
|
+ ' If (T=Nil) then'#013#010+
|
|
|
' Error(SErrDepUnknownTarget,[D.Value, ATarget.Nam'+
|
|
|
- 'e, APackage.Name]);'#010+
|
|
|
- ' // If a dependent package',' is compiled we always '+
|
|
|
- 'need to recompile'#010+
|
|
|
+ 'e, APackage.Name]);'#013#010+
|
|
|
+ ' // If a dependent package is compiled w','e always '+
|
|
|
+ 'need to recompile'#013#010+
|
|
|
' Log(vldebug, SDbgDependencyOnUnit, [ATarget.Name,T'+
|
|
|
- '.Name]);'#010+
|
|
|
- ' Result:=(T.State=tsCompiled);'#010+
|
|
|
- ' if Result then'#010+
|
|
|
- ' begin'#010+
|
|
|
- ' ',' Log(vldebug, SDbgDependencyUnitRecompiled, [T.'+
|
|
|
- 'Name]);'#010+
|
|
|
+ '.Name]);'#013#010+
|
|
|
+ ' Result:=(T.State=tsCompiled);'#013#010+
|
|
|
+ ' if Result then'#013#010+
|
|
|
+ ' begin'#013#010+
|
|
|
+ ' ',' Log(vldebug, SDbgDependencyUnitRecompiled, [T.'+
|
|
|
+ 'Name]);'#013#010+
|
|
|
' CompileReason:=Format(SDbgDependencyRecompiled,['+
|
|
|
- 'T.Name]);'#010+
|
|
|
- ' end;'#010+
|
|
|
- ' end;'#010+
|
|
|
- ' depInclude :'#010+
|
|
|
- ' ',' begin'#010+
|
|
|
- ' if D.TargetFileName<>'#039#039' then'#010+
|
|
|
- ' begin'#010+
|
|
|
+ 'T.Name]);'#013#010+
|
|
|
+ ' end;'#013#010+
|
|
|
+ ' end;'#013#010+
|
|
|
+ ' depInclude :'#013#010+
|
|
|
+ ' ',' begin'#013#010+
|
|
|
+ ' if D.TargetFileName<>'#039#039' then'#013#010+
|
|
|
+ ' begin'#013#010+
|
|
|
' TFN:=AddPathPrefix(APackage,D.TargetFileName);'+
|
|
|
- #010+
|
|
|
- ' Result:=FileNewer(TFN,OFN);'#010+
|
|
|
- ' if r','esult then'#010+
|
|
|
+ #013#010+
|
|
|
+ ' Result:=FileNewer(TFN,OFN);'#013#010+
|
|
|
+ ' if ','result then'#013#010+
|
|
|
' CompileReason:=Format(SDbgNewerInclude,[D.Ta'+
|
|
|
- 'rgetFileName]);'#010+
|
|
|
- ' end;'#010+
|
|
|
- ' end;'#010+
|
|
|
- ' depPackage :'#010+
|
|
|
- ' begin'#010+
|
|
|
- ' log(vlWarning,SWarnT','argetDependsOnPackage,[ATarg'+
|
|
|
- 'et.Name, APackage.Name, d.Value]);'#010+
|
|
|
- ' end;'#010+
|
|
|
- ' end;'#010+
|
|
|
- ' if result then'#010+
|
|
|
- ' break;'#010+
|
|
|
- ' end;'#010+
|
|
|
- ' end;'#010+
|
|
|
- ' end;'#010+
|
|
|
- #010+
|
|
|
- ' if result then'#010+
|
|
|
- ' Log(vlDebug,SDbgMustCo','mpile,[ATarget.Name, CompileReason]);'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
- #010+
|
|
|
- 'procedure TBuildEngine.Compile(APackage: TPackage; ATarget: TTarget);'#010+
|
|
|
- 'Var'#010+
|
|
|
- ' S : String;'#010+
|
|
|
- ' Env : TStrings;'#010+
|
|
|
- 'begin'#010+
|
|
|
- ' Log(vlInfo,SInfoCompilingTarget,[ATarget.Name]);'#010+
|
|
|
- ' LogIndent;'#010+
|
|
|
- ' ExecuteCommands(A','Target.Commands,caBeforeCompile);'#010+
|
|
|
- ' If Assigned(ATarget.BeforeCompile) then'#010+
|
|
|
- ' ATarget.BeforeCompile(ATarget);'#010+
|
|
|
- #010+
|
|
|
+ 'rgetFileName]);'#013#010+
|
|
|
+ ' end;'#013#010+
|
|
|
+ ' end;'#013#010+
|
|
|
+ ' depPackage :'#013#010+
|
|
|
+ ' begin'#013#010+
|
|
|
+ ' log(vlWarning',',SWarnTargetDependsOnPackage,[ATarg'+
|
|
|
+ 'et.Name, APackage.Name, d.Value]);'#013#010+
|
|
|
+ ' end;'#013#010+
|
|
|
+ ' end;'#013#010+
|
|
|
+ ' if result then'#013#010+
|
|
|
+ ' break;'#013#010+
|
|
|
+ ' end;'#013#010+
|
|
|
+ ' end;'#013#010+
|
|
|
+ ' end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ ' if result then'#013#010+
|
|
|
+ ' Log(v','lDebug,SDbgMustCompile,[ATarget.Name, CompileReason]);'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ #013#010+
|
|
|
+ 'procedure TBuildEngine.Compile(APackage: TPackage; ATarget: TTarget);'#013+
|
|
|
+ #010+
|
|
|
+ 'Var'#013#010+
|
|
|
+ ' S : String;'#013#010+
|
|
|
+ ' Env : TStrings;'#013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' Log(vlInfo,SInfoCompilingTarget,[ATarget.Name]);'#013#010+
|
|
|
+ ' Log','Indent;'#013#010+
|
|
|
+ ' ExecuteCommands(ATarget.Commands,caBeforeCompile);'#013#010+
|
|
|
+ ' If Assigned(ATarget.BeforeCompile) then'#013#010+
|
|
|
+ ' ATarget.BeforeCompile(ATarget);'#013#010+
|
|
|
+ #013#010+
|
|
|
' if (APackage.BuildMode=bmBuildUnit) and not (ATarget.TargetType in ['+
|
|
|
- 'ttProgram,ttExampleProgram]) then'#010+
|
|
|
- ' begin'#010+
|
|
|
- ' APackag','e.FBUTarget.Dependencies.AddUnit(ATarget.Name).FTargetF'+
|
|
|
- 'ileName:=ATarget.TargetSourceFileName;'#010+
|
|
|
- ' end'#010+
|
|
|
- ' else'#010+
|
|
|
- ' begin'#010+
|
|
|
- ' if Defaults.UseEnvironment then'#010+
|
|
|
- ' begin'#010+
|
|
|
- ' Env := TStringList.Create;'#010+
|
|
|
- ' try'#010+
|
|
|
- ' S:=Get','CompilerCommand(APackage,ATarget,Env);'#010+
|
|
|
- ' ExecuteCommand(GetCompiler,S,Env);'#010+
|
|
|
- ' finally'#010+
|
|
|
- ' Env.Free;'#010+
|
|
|
- ' end;'#010+
|
|
|
- ' end'#010+
|
|
|
- ' else'#010+
|
|
|
- ' begin'#010+
|
|
|
- ' S:=GetCompilerCommand(APackage,ATarget,Env);'#010+
|
|
|
- ' ',' ExecuteCommand(GetCompiler,S,nil);'#010+
|
|
|
- ' end;'#010+
|
|
|
- ' If Assigned(ATarget.AfterCompile) then'#010+
|
|
|
- ' ATarget.AfterCompile(ATarget);'#010+
|
|
|
- ' ExecuteCommands(ATarget.Commands,caAfterCompile);'#010+
|
|
|
- ' end;'#010+
|
|
|
- ' LogUnIndent;'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
- #010+
|
|
|
- 'procedure TBuildEn','gine.CompileDependencies(APackage:TPackage; ATarge'+
|
|
|
- 't: TTarget);'#010+
|
|
|
- 'Var'#010+
|
|
|
- ' I : Integer;'#010+
|
|
|
- ' T : TTarget;'#010+
|
|
|
- ' D : TDependency;'#010+
|
|
|
- 'begin'#010+
|
|
|
- ' Log(vlDebug, Format(SDbgCompilingDependenciesOfTarget, [ATarget.Name'+
|
|
|
- ']));'#010+
|
|
|
- ' LogIndent;'#010+
|
|
|
- ' For I:=0 to ATarget.Dependen','cies.Count-1 do'#010+
|
|
|
- ' begin'#010+
|
|
|
- ' D:=ATarget.Dependencies[i];'#010+
|
|
|
- ' if (D.DependencyType=depPackage) then'#010+
|
|
|
- ' log(vlWarning,SWarnTargetDependsOnPackage,[ATarget.Name, APack'+
|
|
|
- 'age.Name, d.Value])'#010+
|
|
|
- ' else if (D.DependencyType=depUnit) and'#010+
|
|
|
- ' ',' (Defaults.CPU in D.CPUs) and (Defaults.OS in D.OSes) then'#010+
|
|
|
- ' begin'#010+
|
|
|
- ' T:=TTarget(D.Target);'#010+
|
|
|
- ' if Assigned(T) and (T<>ATarget) then'#010+
|
|
|
- ' begin'#010+
|
|
|
- ' if TargetOK(T, Defaults.CPU, Defaults.OS) then'#010+
|
|
|
- ' ',' begin'#010+
|
|
|
+ 'ttProgram,ttExampleProgra','m]) then'#013#010+
|
|
|
+ ' begin'#013#010+
|
|
|
+ ' APackage.FBUTarget.Dependencies.AddUnit(ATarget.Name).FTargetFil'+
|
|
|
+ 'eName:=ATarget.TargetSourceFileName;'#013#010+
|
|
|
+ ' end'#013#010+
|
|
|
+ ' else'#013#010+
|
|
|
+ ' begin'#013#010+
|
|
|
+ ' if Defaults.UseEnvironment then'#013#010+
|
|
|
+ ' begin'#013#010+
|
|
|
+ ' Env := TStringList.','Create;'#013#010+
|
|
|
+ ' try'#013#010+
|
|
|
+ ' S:=GetCompilerCommand(APackage,ATarget,Env);'#013#010+
|
|
|
+ ' ExecuteCommand(GetCompiler,S,Env);'#013#010+
|
|
|
+ ' finally'#013#010+
|
|
|
+ ' Env.Free;'#013#010+
|
|
|
+ ' end;'#013#010+
|
|
|
+ ' end'#013#010+
|
|
|
+ ' else'#013#010+
|
|
|
+ ' begin'#013#010+
|
|
|
+ ' S:','=GetCompilerCommand(APackage,ATarget,Env);'#013#010+
|
|
|
+ ' ExecuteCommand(GetCompiler,S,nil);'#013#010+
|
|
|
+ ' end;'#013#010+
|
|
|
+ ' If Assigned(ATarget.AfterCompile) then'#013#010+
|
|
|
+ ' ATarget.AfterCompile(ATarget);'#013#010+
|
|
|
+ ' ExecuteCommands(ATarget.Commands,caAfterComp','ile);'#013#010+
|
|
|
+ ' end;'#013#010+
|
|
|
+ ' LogUnIndent;'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ #013#010+
|
|
|
+ 'procedure TBuildEngine.CompileDependencies(APackage:TPackage; ATarget:'+
|
|
|
+ ' TTarget);'#013#010+
|
|
|
+ 'Var'#013#010+
|
|
|
+ ' I : Integer;'#013#010+
|
|
|
+ ' T : TTarget;'#013#010+
|
|
|
+ ' D : TDependency;'#013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' Log(vlDebug, Format(SDbgCompilingDependenciesOfTa','rget, [ATarget.Na'+
|
|
|
+ 'me]));'#013#010+
|
|
|
+ ' LogIndent;'#013#010+
|
|
|
+ ' For I:=0 to ATarget.Dependencies.Count-1 do'#013#010+
|
|
|
+ ' begin'#013#010+
|
|
|
+ ' D:=ATarget.Dependencies[i];'#013#010+
|
|
|
+ ' if (D.DependencyType=depPackage) then'#013#010+
|
|
|
+ ' log(vlWarning,SWarnTargetDependsOnPackage,[ATarget.Name',', APa'+
|
|
|
+ 'ckage.Name, d.Value])'#013#010+
|
|
|
+ ' else if (D.DependencyType=depUnit) and'#013#010+
|
|
|
+ ' (Defaults.CPU in D.CPUs) and (Defaults.OS in D.OSes) then'#013+
|
|
|
+ #010+
|
|
|
+ ' begin'#013#010+
|
|
|
+ ' T:=TTarget(D.Target);'#013#010+
|
|
|
+ ' if Assigned(T) and (T<>ATarget) then'#013#010+
|
|
|
+ ' ',' begin'#013#010+
|
|
|
+ ' if TargetOK(T, Defaults.CPU, Defaults.OS) then'#013#010+
|
|
|
+ ' begin'#013#010+
|
|
|
' // We don'#039't need to compile implicit units, they'+
|
|
|
- ' are only'#010+
|
|
|
- ' // used for dependency checking'#010+
|
|
|
- ' if (T.TargetType<>ttImplicitUnit) then'#010+
|
|
|
- ' begin'#010+
|
|
|
- ' ',' case T.State of'#010+
|
|
|
- ' tsNeutral :'#010+
|
|
|
- ' MaybeCompile(APackage,T);'#010+
|
|
|
- ' tsConsidering :'#010+
|
|
|
+ ' are only'#013#010+
|
|
|
+ ' // used for dependency checking'#013#010+
|
|
|
+ ' ',' if (T.TargetType<>ttImplicitUnit) then'#013#010+
|
|
|
+ ' begin'#013#010+
|
|
|
+ ' case T.State of'#013#010+
|
|
|
+ ' tsNeutral :'#013#010+
|
|
|
+ ' MaybeCompile(APackage,T);'#013#010+
|
|
|
+ ' tsConsiderin','g :'#013#010+
|
|
|
' Log(vlWarning,SWarnCircularTargetDependency,'+
|
|
|
- '[ATarget.Name,T','.Name]);'#010+
|
|
|
- ' end;'#010+
|
|
|
- ' end;'#010+
|
|
|
- ' end'#010+
|
|
|
- ' else'#010+
|
|
|
- ' Log(vlWarning, Format(SWarnDepUnitNotFound, [T.Name, M'+
|
|
|
- 'akeTargetString(Defaults.CPU,Defaults.OS)]));'#010+
|
|
|
- ' end'#010+
|
|
|
- ' ',' else'#010+
|
|
|
+ '[ATarget.Name,T.Name]);'#013#010+
|
|
|
+ ' end;'#013#010+
|
|
|
+ ' end;'#013#010+
|
|
|
+ ' end'#013#010+
|
|
|
+ ' else'#013#010+
|
|
|
+ ' Log(vlWarning, Format(SWarnDe','pUnitNotFound, [T.Name,'+
|
|
|
+ ' MakeTargetString(Defaults.CPU,Defaults.OS)]));'#013#010+
|
|
|
+ ' end'#013#010+
|
|
|
+ ' else'#013#010+
|
|
|
' Error(SErrDepUnknownTarget,[D.Value, ATarget.Name, APackag'+
|
|
|
- 'e.Name]);'#010+
|
|
|
- ' end;'#010+
|
|
|
- ' end;'#010+
|
|
|
- ' LogUnIndent;'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
- #010+
|
|
|
- 'procedure TBuildEngine.MaybeCompile(APackage: TPackage; ATarget: TTarg'+
|
|
|
- 'et);'#010+
|
|
|
- 'begin'#010+
|
|
|
- ' if ATarget.State<>tsNeutra','l then'#010+
|
|
|
- ' Error(SErrInvalidState,[ATarget.Name]);'#010+
|
|
|
- ' Log(vlDebug, Format(SDbgConsideringTarget, [ATarget.Name]));'#010+
|
|
|
- ' LogIndent;'#010+
|
|
|
- ' ATarget.FTargetState:=tsConsidering;'#010+
|
|
|
+ 'e.Name]);'#013#010+
|
|
|
+ ' end;'#013#010+
|
|
|
+ ' end;'#013#010+
|
|
|
+ ' LogUnIndent;'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ #013#010+
|
|
|
+ 'proc','edure TBuildEngine.MaybeCompile(APackage: TPackage; ATarget: TTa'+
|
|
|
+ 'rget);'#013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' if ATarget.State<>tsNeutral then'#013#010+
|
|
|
+ ' Error(SErrInvalidState,[ATarget.Name]);'#013#010+
|
|
|
+ ' Log(vlDebug, Format(SDbgConsideringTarget, [ATarget.Name]));'#013#010+
|
|
|
+ ' LogIndent;'#013#010+
|
|
|
+ ' ','ATarget.FTargetState:=tsConsidering;'#013#010+
|
|
|
' ResolveDependencies(ATarget.Dependencies,ATarget.Collection as TTarg'+
|
|
|
- 'ets)',';'#010+
|
|
|
- ' CompileDependencies(APackage, ATarget);'#010+
|
|
|
- ' if NeedsCompile(APackage, ATarget) then'#010+
|
|
|
- ' begin'#010+
|
|
|
- ' Compile(APackage,ATarget);'#010+
|
|
|
- ' ATarget.FTargetState:=tsCompiled;'#010+
|
|
|
- ' end'#010+
|
|
|
- ' else'#010+
|
|
|
- ' ATarget.FTargetState:=tsNoCompile;'#010+
|
|
|
- ' LogUnIndent;'#010+
|
|
|
- 'en','d;'#010+
|
|
|
- #010+
|
|
|
- #010+
|
|
|
- 'function TBuildEngine.NeedsCompile(APackage: TPackage): Boolean;'#010+
|
|
|
- 'Var'#010+
|
|
|
- ' I : Integer;'#010+
|
|
|
- ' P : TPackage;'#010+
|
|
|
- ' D : TDependency;'#010+
|
|
|
- ' CompileReason: string;'#010+
|
|
|
- 'begin'#010+
|
|
|
- ' Result:=False;'#010+
|
|
|
- #010+
|
|
|
- ' // Forced recompile?'#010+
|
|
|
- ' if FForceCompile then'#010+
|
|
|
- ' begin'#010+
|
|
|
- ' Result',':=true;'#010+
|
|
|
- ' CompileReason:=SDbgForcedCompile;'#010+
|
|
|
- ' end;'#010+
|
|
|
- #010+
|
|
|
- ' // Recompile because of Package Dependencies?'#010+
|
|
|
- ' if not Result then'#010+
|
|
|
- ' begin'#010+
|
|
|
- ' I:=0;'#010+
|
|
|
- ' For I:=0 to APackage.Dependencies.Count-1 do'#010+
|
|
|
- ' begin'#010+
|
|
|
- ' D:=APackage.De','pendencies[i];'#010+
|
|
|
- ' if (D.DependencyType=depPackage) and'#010+
|
|
|
- ' (Defaults.CPU in D.CPUs) and (Defaults.OS in D.OSes) the'+
|
|
|
- 'n'#010+
|
|
|
- ' begin'#010+
|
|
|
- ' P:=TPackage(D.Target);'#010+
|
|
|
- ' if Assigned(P) then'#010+
|
|
|
- ' ',' begin'#010+
|
|
|
- ' Result:=(P.State=tsCompiled);'#010+
|
|
|
- ' if Result then'#010+
|
|
|
- ' begin'#010+
|
|
|
- ' break;'#010+
|
|
|
+ 'ets);'#013#010+
|
|
|
+ ' CompileDependencies(APackage, ATarget);'#013#010+
|
|
|
+ ' if NeedsCompile(APackage, ATarget) then'#013#010+
|
|
|
+ ' begin'#013#010+
|
|
|
+ ' Compile(APackage,ATarg','et);'#013#010+
|
|
|
+ ' ATarget.FTargetState:=tsCompiled;'#013#010+
|
|
|
+ ' end'#013#010+
|
|
|
+ ' else'#013#010+
|
|
|
+ ' ATarget.FTargetState:=tsNoCompile;'#013#010+
|
|
|
+ ' LogUnIndent;'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ #013#010+
|
|
|
+ 'function TBuildEngine.NeedsCompile(APackage: TPackage): Boolean;'#013#010+
|
|
|
+ 'Var'#013#010+
|
|
|
+ ' I : Integer;'#013#010+
|
|
|
+ ' P : TPackage;'#013#010+
|
|
|
+ ' D : ','TDependency;'#013#010+
|
|
|
+ ' CompileReason: string;'#013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' Result:=False;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ ' // Forced recompile?'#013#010+
|
|
|
+ ' if FForceCompile then'#013#010+
|
|
|
+ ' begin'#013#010+
|
|
|
+ ' Result:=true;'#013#010+
|
|
|
+ ' CompileReason:=SDbgForcedCompile;'#013#010+
|
|
|
+ ' end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ ' // Recompile because of Package Dependenc','ies?'#013#010+
|
|
|
+ ' if not Result then'#013#010+
|
|
|
+ ' begin'#013#010+
|
|
|
+ ' I:=0;'#013#010+
|
|
|
+ ' For I:=0 to APackage.Dependencies.Count-1 do'#013#010+
|
|
|
+ ' begin'#013#010+
|
|
|
+ ' D:=APackage.Dependencies[i];'#013#010+
|
|
|
+ ' if (D.DependencyType=depPackage) and'#013#010+
|
|
|
+ ' (Defaults.CPU ','in D.CPUs) and (Defaults.OS in D.OSes) t'+
|
|
|
+ 'hen'#013#010+
|
|
|
+ ' begin'#013#010+
|
|
|
+ ' P:=TPackage(D.Target);'#013#010+
|
|
|
+ ' if Assigned(P) then'#013#010+
|
|
|
+ ' begin'#013#010+
|
|
|
+ ' Result:=(P.State=tsCompiled);'#013#010+
|
|
|
+ ' if Resu','lt then'#013#010+
|
|
|
+ ' begin'#013#010+
|
|
|
+ ' break;'#013#010+
|
|
|
' CompileReason:=Format(SDbgPackageDepRecompiled,[P'+
|
|
|
- '.Name]);'#010+
|
|
|
- ' ',' end;'#010+
|
|
|
- ' end;'#010+
|
|
|
- ' end;'#010+
|
|
|
- ' end;'#010+
|
|
|
- ' end;'#010+
|
|
|
- #010+
|
|
|
- ' // Recompile a Target of this package?'#010+
|
|
|
- ' If Not Result then'#010+
|
|
|
- ' begin'#010+
|
|
|
- ' GPathPrefix := APackage.Directory;'#010+
|
|
|
- ' try'#010+
|
|
|
- ' for i:=0 to APackage.Targets.Cou','nt-1 do'#010+
|
|
|
- ' begin'#010+
|
|
|
- ' Result:=NeedsCompile(APackage,APackage.Targets.TargetItems'+
|
|
|
- '[i]);'#010+
|
|
|
- ' if Result then'#010+
|
|
|
- ' begin'#010+
|
|
|
- ' break;'#010+
|
|
|
+ '.Name]);'#013#010+
|
|
|
+ ' end;'#013#010+
|
|
|
+ ' end;'#013#010+
|
|
|
+ ' end;'#013#010+
|
|
|
+ ' end;'#013#010+
|
|
|
+ ' end;'#013#010,
|
|
|
+ #013#010+
|
|
|
+ ' // Recompile a Target of this package?'#013#010+
|
|
|
+ ' If Not Result then'#013#010+
|
|
|
+ ' begin'#013#010+
|
|
|
+ ' GPathPrefix := APackage.Directory;'#013#010+
|
|
|
+ ' try'#013#010+
|
|
|
+ ' for i:=0 to APackage.Targets.Count-1 do'#013#010+
|
|
|
+ ' begin'#013#010+
|
|
|
+ ' Result:=NeedsCompile(APackage,AP','ackage.Targets.TargetIte'+
|
|
|
+ 'ms[i]);'#013#010+
|
|
|
+ ' if Result then'#013#010+
|
|
|
+ ' begin'#013#010+
|
|
|
+ ' break;'#013#010+
|
|
|
' CompileReason:=Format(SDbgTargetHasToBeCompiled,[APackag'+
|
|
|
- 'e.','Targets.TargetItems[i].Name]);'#010+
|
|
|
- ' end;'#010+
|
|
|
- ' end;'#010+
|
|
|
- ' Finally'#010+
|
|
|
- ' GPathPrefix := '#039#039';'#010+
|
|
|
- ' end;'#010+
|
|
|
- ' end;'#010+
|
|
|
- #010+
|
|
|
- ' if result then'#010+
|
|
|
- ' Log(vlDebug,SDbgMustCompile,[APackage.Name, CompileReason]);'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
- #010+
|
|
|
- 'function TBuildEngine.Ch','eckExternalPackage(Const APackageName : Stri'+
|
|
|
- 'ng):TPackage;'#010+
|
|
|
- 'var'#010+
|
|
|
- ' S : String;'#010+
|
|
|
- ' F : String;'#010+
|
|
|
- ' I : Integer;'#010+
|
|
|
- 'begin'#010+
|
|
|
- ' // Already checked?'#010+
|
|
|
- ' I:=ExternalPackages.IndexOfName(APackageName);'#010+
|
|
|
- ' if I<>-1 then'#010+
|
|
|
- ' begin'#010+
|
|
|
- ' result:=ExternalPackages.P','ackageItems[I];'#010+
|
|
|
- ' exit;'#010+
|
|
|
- ' end;'#010+
|
|
|
- ' // Create new external package'#010+
|
|
|
- ' Result:=ExternalPackages.AddPackage(APackageName);'#010+
|
|
|
- ' Result.FTargetState:=tsNotFound;'#010+
|
|
|
- ' // Load unit config'#010+
|
|
|
- ' S:=GetUnitDir(Result);'#010+
|
|
|
- ' if S<>'#039#039' then'#010+
|
|
|
- ' begin'#010+
|
|
|
- ' Log','(vldebug, SDbgExternalDependency, [APackageName,S]);'#010+
|
|
|
- ' // Load unit config if it exists'#010+
|
|
|
- ' F:=IncludeTrailingPathDelimiter(S)+UnitConfigFile;'#010+
|
|
|
- ' if FileExists(F) then'#010+
|
|
|
- ' begin'#010+
|
|
|
- ' Log(vlDebug, Format(SDbgLoading, [F]));',#010+
|
|
|
- ' Result.LoadUnitConfigFromFile(F);'#010+
|
|
|
- ' result.SetDefaultPackageVariant;'#010+
|
|
|
+ 'e.Targets.TargetItems[i].Name]);'#013#010+
|
|
|
+ ' end;'#013#010+
|
|
|
+ ' en','d;'#013#010+
|
|
|
+ ' Finally'#013#010+
|
|
|
+ ' GPathPrefix := '#039#039';'#013#010+
|
|
|
+ ' end;'#013#010+
|
|
|
+ ' end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ ' if result then'#013#010+
|
|
|
+ ' Log(vlDebug,SDbgMustCompile,[APackage.Name, CompileReason]);'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ #013#010+
|
|
|
+ 'function TBuildEngine.CheckExternalPackage(Const APackageName : String'+
|
|
|
+ '):TPa','ckage;'#013#010+
|
|
|
+ 'var'#013#010+
|
|
|
+ ' S : String;'#013#010+
|
|
|
+ ' F : String;'#013#010+
|
|
|
+ ' I : Integer;'#013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' // Already checked?'#013#010+
|
|
|
+ ' I:=ExternalPackages.IndexOfName(APackageName);'#013#010+
|
|
|
+ ' if I<>-1 then'#013#010+
|
|
|
+ ' begin'#013#010+
|
|
|
+ ' result:=ExternalPackages.PackageItems[I];'#013#010+
|
|
|
+ ' exit;'#013#010+
|
|
|
+ ' end;'#013#010+
|
|
|
+ ' ',' // Create new external package'#013#010+
|
|
|
+ ' Result:=ExternalPackages.AddPackage(APackageName);'#013#010+
|
|
|
+ ' Result.FTargetState:=tsNotFound;'#013#010+
|
|
|
+ ' // Load unit config'#013#010+
|
|
|
+ ' S:=GetUnitDir(Result);'#013#010+
|
|
|
+ ' if S<>'#039#039' then'#013#010+
|
|
|
+ ' begin'#013#010+
|
|
|
+ ' Log(vldebug, SDbgExternalDependenc','y, [APackageName,S]);'#013#010+
|
|
|
+ ' // Load unit config if it exists'#013#010+
|
|
|
+ ' F:=IncludeTrailingPathDelimiter(S)+UnitConfigFile;'#013#010+
|
|
|
+ ' if FileExists(F) then'#013#010+
|
|
|
+ ' begin'#013#010+
|
|
|
+ ' Log(vlDebug, Format(SDbgLoading, [F]));'#013#010+
|
|
|
+ ' Result.LoadUni','tConfigFromFile(F);'#013#010+
|
|
|
+ ' result.SetDefaultPackageVariant;'#013#010+
|
|
|
' result.UnitDir:=result.UnitDir+Result.GetPackageUnitInstallD'+
|
|
|
- 'ir(Defaults.CPU, Defaults.OS);'#010+
|
|
|
- ' end;'#010+
|
|
|
- ' // Check recursive implicit depe','ndencies'#010+
|
|
|
- ' CompileDependencies(Result);'#010+
|
|
|
- ' end'#010+
|
|
|
- ' else'#010+
|
|
|
- ' Error(SErrDependencyNotFound,[APackageName]);'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
- #010+
|
|
|
- 'procedure TBuildEngine.CompileDependencies(APackage: TPackage);'#010+
|
|
|
- 'Var'#010+
|
|
|
- ' I : Integer;'#010+
|
|
|
- ' P : TPackage;'#010+
|
|
|
- ' D : TDependency;'#010+
|
|
|
- 'begin'#010,
|
|
|
- ' For I:=0 to APackage.Dependencies.Count-1 do'#010+
|
|
|
- ' begin'#010+
|
|
|
- ' D:=APackage.Dependencies[i];'#010+
|
|
|
- ' if (D.DependencyType=depPackage) and'#010+
|
|
|
- ' (Defaults.CPU in D.CPUs) and (Defaults.OS in D.OSes) then'#010+
|
|
|
- ' begin'#010+
|
|
|
- ' P:=TPackage(D.','Target);'#010+
|
|
|
- ' If Assigned(P) then'#010+
|
|
|
- ' begin'#010+
|
|
|
+ 'ir(Defaults.CPU, Defaults.OS);'#013#010+
|
|
|
+ ' end;'#013#010+
|
|
|
+ ' // Check recursive implicit dependencies'#013#010+
|
|
|
+ ' Compi','leDependencies(Result);'#013#010+
|
|
|
+ ' end'#013#010+
|
|
|
+ ' else'#013#010+
|
|
|
+ ' Error(SErrDependencyNotFound,[APackageName]);'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ #013#010+
|
|
|
+ 'procedure TBuildEngine.CompileDependencies(APackage: TPackage);'#013#010+
|
|
|
+ 'Var'#013#010+
|
|
|
+ ' I : Integer;'#013#010+
|
|
|
+ ' P : TPackage;'#013#010+
|
|
|
+ ' D : TDependency;'#013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' For I',':=0 to APackage.Dependencies.Count-1 do'#013#010+
|
|
|
+ ' begin'#013#010+
|
|
|
+ ' D:=APackage.Dependencies[i];'#013#010+
|
|
|
+ ' if (D.DependencyType=depPackage) and'#013#010+
|
|
|
+ ' (Defaults.CPU in D.CPUs) and (Defaults.OS in D.OSes) then'#013+
|
|
|
+ #010+
|
|
|
+ ' begin'#013#010+
|
|
|
+ ' P:=TPackage(D.T','arget);'#013#010+
|
|
|
+ ' If Assigned(P) then'#013#010+
|
|
|
+ ' begin'#013#010+
|
|
|
' if (Defaults.CPU in P.CPUs) and (Defaults.OS in P.OSes) '+
|
|
|
- 'then'#010+
|
|
|
- ' begin'#010+
|
|
|
- ' case P.State of'#010+
|
|
|
- ' tsNeutral :'#010+
|
|
|
- ' ',' MaybeCompile(P);'#010+
|
|
|
- ' tsConsidering :'#010+
|
|
|
+ 'then'#013#010+
|
|
|
+ ' begin'#013#010+
|
|
|
+ ' case P.State of'#013#010+
|
|
|
+ ' tsNeutral :'#013#010+
|
|
|
+ ' ',' MaybeCompile(P);'#013#010+
|
|
|
+ ' tsConsidering :'#013#010+
|
|
|
' Log(vlWarning,SWarnCircularPackageDependency,[AP'+
|
|
|
- 'ackage.Name,P.Name]);'#010+
|
|
|
- ' end;'#010+
|
|
|
- ' end'#010+
|
|
|
- ' else'#010+
|
|
|
- ' Log(vlWarning,S','WarnDependOnOtherPlatformPackage,[APa'+
|
|
|
- 'ckage.Name, D.Value, MakeTargetString(Defaults.CPU, Defaults.OS)]);'#010+
|
|
|
- ' end'#010+
|
|
|
- ' else'#010+
|
|
|
- ' begin'#010+
|
|
|
- ' D.Target:=CheckExternalPackage(D.Value);'#010+
|
|
|
- ' P:=TPackage(D.Tar','get);'#010+
|
|
|
- ' end;'#010+
|
|
|
- ' if (D.RequireChecksum<>$ffffffff) and'#010+
|
|
|
- ' (P.InstalledChecksum<>$ffffffff) and'#010+
|
|
|
- ' (P.InstalledChecksum<>D.RequireChecksum) then'#010+
|
|
|
- ' Log(vlDebug,SDbgPackageChecksumChanged,[P.Name])',';'#010+
|
|
|
- ' APackage.InheritPackageVariantsFromDependency(P);'#010+
|
|
|
- ' end;'#010+
|
|
|
- ' end;'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
+ 'ackage.Name,P.Name]);'#013#010+
|
|
|
+ ' end;'#013#010+
|
|
|
+ ' end'#013#010+
|
|
|
+ ' else'#013#010+
|
|
|
+ ' Log','(vlWarning,SWarnDependOnOtherPlatformPackage,[APa'+
|
|
|
+ 'ckage.Name, D.Value, MakeTargetString(Defaults.CPU, Defaults.OS)]);'#013+
|
|
|
+ #010+
|
|
|
+ ' end'#013#010+
|
|
|
+ ' else'#013#010+
|
|
|
+ ' begin'#013#010+
|
|
|
+ ' D.Target:=CheckExternalPackage(D.Value);'#013#010+
|
|
|
+ ' ','P:=TPackage(D.Target);'#013#010+
|
|
|
+ ' end;'#013#010+
|
|
|
+ ' if (D.RequireChecksum<>$ffffffff) and'#013#010+
|
|
|
+ ' (P.InstalledChecksum<>$ffffffff) and'#013#010+
|
|
|
+ ' (P.InstalledChecksum<>D.RequireChecksum) then'#013#010+
|
|
|
+ ' Log(vlDebug,SDbgPackageChe','cksumChanged,[P.Name]);'#013#010+
|
|
|
+ ' APackage.InheritPackageVariantsFromDependency(P);'#013#010+
|
|
|
+ ' end;'#013#010+
|
|
|
+ ' end;'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
'function TBuildEngine.CheckDependencies(APackage: TPackage): TCheckDep'+
|
|
|
- 'endencyResult;'#010+
|
|
|
- 'Var'#010+
|
|
|
- ' I : Integer;'#010+
|
|
|
- ' P : TPackage;'#010+
|
|
|
- ' D : TDependency;'#010+
|
|
|
- 'begin'#010+
|
|
|
- ' res','ult := cdAvailable;'#010+
|
|
|
- ' For I:=0 to APackage.Dependencies.Count-1 do'#010+
|
|
|
- ' begin'#010+
|
|
|
- ' D:=APackage.Dependencies[i];'#010+
|
|
|
- ' if (D.DependencyType=depPackage) and'#010+
|
|
|
- ' (Defaults.CPU in D.CPUs) and (Defaults.OS in D.OSes) then'#010+
|
|
|
- ' begin'#010+
|
|
|
- ' ',' P:=TPackage(D.Target);'#010+
|
|
|
- ' If Assigned(P) then'#010+
|
|
|
- ' begin'#010+
|
|
|
+ 'endencyResult;'#013#010+
|
|
|
+ 'Var'#013#010+
|
|
|
+ ' I : Integer;'#013#010+
|
|
|
+ ' P : TPackage;',#013#010+
|
|
|
+ ' D : TDependency;'#013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' result := cdAvailable;'#013#010+
|
|
|
+ ' For I:=0 to APackage.Dependencies.Count-1 do'#013#010+
|
|
|
+ ' begin'#013#010+
|
|
|
+ ' D:=APackage.Dependencies[i];'#013#010+
|
|
|
+ ' if (D.DependencyType=depPackage) and'#013#010+
|
|
|
+ ' (Defaults.CPU in D.CPUs) and (Default','s.OS in D.OSes) then'#013+
|
|
|
+ #010+
|
|
|
+ ' begin'#013#010+
|
|
|
+ ' P:=TPackage(D.Target);'#013#010+
|
|
|
+ ' If Assigned(P) then'#013#010+
|
|
|
+ ' begin'#013#010+
|
|
|
' if (Defaults.CPU in P.CPUs) and (Defaults.OS in P.OSes) '+
|
|
|
- 'then'#010+
|
|
|
- ' begin'#010+
|
|
|
- ' case P.State of'#010+
|
|
|
- ' tsNeutral :'#010,
|
|
|
- ' result := cdNotYetAvailable;'#010+
|
|
|
- ' tsConsidering :'#010+
|
|
|
+ 'then'#013#010+
|
|
|
+ ' begin'#013#010+
|
|
|
+ ' ca','se P.State of'#013#010+
|
|
|
+ ' tsNeutral :'#013#010+
|
|
|
+ ' result := cdNotYetAvailable;'#013#010+
|
|
|
+ ' tsConsidering :'#013#010+
|
|
|
' Log(vlWarning,SWarnCircularPackageDependency,[AP'+
|
|
|
- 'ackage.Name,P.Name]);'#010+
|
|
|
- ' end;'#010+
|
|
|
- ' end'#010+
|
|
|
- ' else',#010+
|
|
|
+ 'ackage.Name,P.Name]);'#013#010+
|
|
|
+ ' ',' end;'#013#010+
|
|
|
+ ' end'#013#010+
|
|
|
+ ' else'#013#010+
|
|
|
' Log(vlWarning,SWarnDependOnOtherPlatformPackage,[APack'+
|
|
|
- 'age.Name, D.Value, MakeTargetString(Defaults.CPU, Defaults.OS)]);'#010+
|
|
|
- ' end'#010+
|
|
|
- ' else'#010+
|
|
|
- ' begin'#010+
|
|
|
- ' D.Target:=CheckExternalPackage(D.Value);',#010+
|
|
|
- ' P:=TPackage(D.Target);'#010+
|
|
|
- ' end;'#010+
|
|
|
- ' if (D.RequireChecksum<>$ffffffff) and'#010+
|
|
|
- ' (P.InstalledChecksum<>$ffffffff) and'#010+
|
|
|
- ' (P.InstalledChecksum<>D.RequireChecksum) then'#010+
|
|
|
- ' Log(vlDebug,SDbg','PackageChecksumChanged,[P.Name]);'#010+
|
|
|
- ' APackage.InheritPackageVariantsFromDependency(P);'#010+
|
|
|
- ' end;'#010+
|
|
|
- ' end;'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
- #010+
|
|
|
- 'procedure TBuildEngine.Compile(APackage: TPackage);'#010+
|
|
|
- 'Var'#010+
|
|
|
- ' T : TTarget;'#010+
|
|
|
- ' I : Integer;'#010+
|
|
|
- ' Cmd: string;'#010+
|
|
|
- ' cmdOpts: strin','g;'#010+
|
|
|
- ' sFPDocFormat: string;'#010+
|
|
|
- ' IFPDocFormat: TFPDocFormat;'#010+
|
|
|
- ' d: integer;'#010+
|
|
|
- ' UC: string;'#010+
|
|
|
- ' dep: TDependency;'#010+
|
|
|
- ' RegenerateUnitconfigFile: boolean;'#010+
|
|
|
- ' BUName: string;'#010+
|
|
|
- #010+
|
|
|
- ' procedure CompileBuildUnit;'#010+
|
|
|
- ' var'#010+
|
|
|
- ' I: Integer;'#010+
|
|
|
- ' T: TTarget;'#010+
|
|
|
- ' L: TStr','ings;'#010+
|
|
|
- ' F: Text;'#010+
|
|
|
- #010+
|
|
|
- ' begin'#010+
|
|
|
- ' if (APackage.FBUTarget.Dependencies.Count>0) then'#010+
|
|
|
- ' begin'#010+
|
|
|
- ' Log(vldebug, Format(SDbgGenerateBuildUnit, [APackage.FBUTarget'+
|
|
|
- '.Name]));'#010+
|
|
|
- ' system.Assign(F,AddPathPrefix(APackage,APackage.FBUTarget.','FT'+
|
|
|
- 'argetSourceFileName));'#010+
|
|
|
- ' Rewrite(F);'#010+
|
|
|
+ 'age.Name, D.Value, MakeTargetString(Defaults.CPU, Defaults.OS)]);'#013#010+
|
|
|
+ ' end'#013#010+
|
|
|
+ ' else'#013#010+
|
|
|
+ ' beg','in'#013#010+
|
|
|
+ ' D.Target:=CheckExternalPackage(D.Value);'#013#010+
|
|
|
+ ' P:=TPackage(D.Target);'#013#010+
|
|
|
+ ' end;'#013#010+
|
|
|
+ ' if (D.RequireChecksum<>$ffffffff) and'#013#010+
|
|
|
+ ' (P.InstalledChecksum<>$ffffffff) and'#013#010+
|
|
|
+ ' (P.Installe','dChecksum<>D.RequireChecksum) then'#013#010+
|
|
|
+ ' Log(vlDebug,SDbgPackageChecksumChanged,[P.Name]);'#013#010+
|
|
|
+ ' APackage.InheritPackageVariantsFromDependency(P);'#013#010+
|
|
|
+ ' end;'#013#010+
|
|
|
+ ' end;'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ #013#010+
|
|
|
+ 'procedure TBuildEngine.Compile(APackage: TPack','age);'#013#010+
|
|
|
+ 'Var'#013#010+
|
|
|
+ ' T : TTarget;'#013#010+
|
|
|
+ ' I : Integer;'#013#010+
|
|
|
+ ' Cmd: string;'#013#010+
|
|
|
+ ' cmdOpts: string;'#013#010+
|
|
|
+ ' sFPDocFormat: string;'#013#010+
|
|
|
+ ' IFPDocFormat: TFPDocFormat;'#013#010+
|
|
|
+ ' d: integer;'#013#010+
|
|
|
+ ' UC: string;'#013#010+
|
|
|
+ ' dep: TDependency;'#013#010+
|
|
|
+ ' RegenerateUnitconfigFile: boolean;'#013#010+
|
|
|
+ ' BUName: strin','g;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ ' procedure CompileBuildUnit;'#013#010+
|
|
|
+ ' var'#013#010+
|
|
|
+ ' I: Integer;'#013#010+
|
|
|
+ ' T: TTarget;'#013#010+
|
|
|
+ ' L: TStrings;'#013#010+
|
|
|
+ ' F: Text;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ ' begin'#013#010+
|
|
|
+ ' if (APackage.FBUTarget.Dependencies.Count>0) then'#013#010+
|
|
|
+ ' begin'#013#010+
|
|
|
+ ' Log(vldebug, Format(SDbgGenerateBuildUnit, ','[APackage.FBUTarg'+
|
|
|
+ 'et.Name]));'#013#010+
|
|
|
+ ' system.Assign(F,AddPathPrefix(APackage,APackage.FBUTarget.FTar'+
|
|
|
+ 'getSourceFileName));'#013#010+
|
|
|
+ ' Rewrite(F);'#013#010+
|
|
|
' writeln(F,'#039'unit '#039' + APackage.FBUTarget.Name +'#039';'#039+
|
|
|
- ');'#010+
|
|
|
- ' writeln(F,'#039'interface'#039');'#010+
|
|
|
- ' writeln(F,'#039'uses'#039');'#010+
|
|
|
- ' for i := 0 to APackage.FBUTarget.Dependencies.Count-1 do'#010+
|
|
|
- ' be','gin'#010+
|
|
|
- ' if i<>0 then'#010+
|
|
|
- ' write(F,'#039','#039');'#010+
|
|
|
+ ');'#013#010+
|
|
|
+ ' writeln(F,'#039'interface'#039');'#013#010+
|
|
|
+ ' ',' writeln(F,'#039'uses'#039');'#013#010+
|
|
|
+ ' for i := 0 to APackage.FBUTarget.Dependencies.Count-1 do'#013#010+
|
|
|
+ ' begin'#013#010+
|
|
|
+ ' if i<>0 then'#013#010+
|
|
|
+ ' write(F,'#039','#039');'#013#010+
|
|
|
' writeln(F,APackage.FBUTarget.Dependencies.Dependencies[i].'+
|
|
|
- 'Value);'#010+
|
|
|
- ' end;'#010+
|
|
|
- ' writeln(F,'#039';'#039');'#010+
|
|
|
- ' writeln(F,'#039'implementation'#039');'#010+
|
|
|
- ' writeln(F,'#039'end.'#039');'#010+
|
|
|
- #010+
|
|
|
- ' ',' system.close(F);'#010+
|
|
|
- #010+
|
|
|
- ' APackage.FBuildMode:=bmOneByOne;'#010+
|
|
|
- ' try'#010+
|
|
|
- ' Compile(APackage,APackage.FBUTarget);'#010+
|
|
|
- ' finally'#010+
|
|
|
- ' // Delete temporary build-unit files'#010+
|
|
|
- ' L := TStringList.Create;'#010+
|
|
|
- ' try'#010+
|
|
|
- ' ',' APackage.FBUTarget.GetCleanFiles(L,IncludeTrailingPathDe'+
|
|
|
- 'limiter(AddPathPrefix(APackage,APackage.GetUnitsOutputDir(Defaults.CPU'+
|
|
|
- ',Defaults.OS))),'#039#039',Defaults.CPU,Defaults.OS);'#010+
|
|
|
- ' L.Add(AddPathPrefix(APackage,APackage.FBUTarge','t.SourceFi'+
|
|
|
- 'leName));'#010+
|
|
|
- ' CmdDeleteFiles(L);'#010+
|
|
|
- ' finally'#010+
|
|
|
- ' L.Free;'#010+
|
|
|
- ' end;'#010+
|
|
|
- ' end;'#010+
|
|
|
- ' end;'#010+
|
|
|
- #010+
|
|
|
- ' For I:=0 to APackage.Targets.Count-1 do'#010+
|
|
|
- ' begin'#010+
|
|
|
- ' T:=APackage.Targets.TargetItems[i];'#010+
|
|
|
- ' if ','(T.TargetType = ttUnit) and (TargetOK(T, Defaults.CPU, De'+
|
|
|
- 'faults.OS)) then'#010+
|
|
|
- ' begin'#010+
|
|
|
- ' If Assigned(T.AfterCompile) then'#010+
|
|
|
- ' T.AfterCompile(T);'#010+
|
|
|
- ' ExecuteCommands(T.Commands,caAfterCompile);'#010+
|
|
|
- ' end'#010+
|
|
|
- ' ',' end;'#010+
|
|
|
- ' end;'#010+
|
|
|
- #010+
|
|
|
- ' procedure ProcessCompileTarget;'#010+
|
|
|
- ' begin'#010+
|
|
|
- ' if TargetOK(T, Defaults.CPU, Defaults.OS) then'#010+
|
|
|
- ' begin'#010+
|
|
|
- ' if T.State=tsNeutral then'#010+
|
|
|
- ' MaybeCompile(APackage,T);'#010+
|
|
|
- ' // If a target is compiled, re-generate ','the UnitConfigFile'#010+
|
|
|
- ' if T.FTargetState<>tsNoCompile then'#010+
|
|
|
- ' RegenerateUnitconfigFile:= True;'#010+
|
|
|
- ' end'#010+
|
|
|
- ' else'#010+
|
|
|
- ' begin'#010+
|
|
|
- ' if not(Defaults.CPU in T.CPUs) then'#010+
|
|
|
- ' Log(vldebug, Format(SDbgSkippingTargetWrongCPU, [','T.Name, C'+
|
|
|
- 'PUsToString(T.CPUs)]));'#010+
|
|
|
- ' if not(Defaults.OS in T.OSes) then'#010+
|
|
|
- ' Log(vldebug, Format(SDbgSkippingTargetWrongOS, [T.Name, OSes'+
|
|
|
- 'ToString(T.OSes)]));'#010+
|
|
|
- ' end;'#010+
|
|
|
- ' end;'#010+
|
|
|
- #010+
|
|
|
- 'begin'#010+
|
|
|
- ' cmdOpts := '#039#039';'#010+
|
|
|
- #010+
|
|
|
- ' log(vlWarning,SWarnStartComp','ilingPackage,[APackage.Name, Defaults.'+
|
|
|
- 'Target]);'#010+
|
|
|
- #010+
|
|
|
- ' case Defaults.BuildMode of'#010+
|
|
|
- ' bmOneByOne: begin'#010+
|
|
|
- ' if (bmOneByOne in APackage.SupportBuildModes) then'#010+
|
|
|
- ' APackage.FBuildMode:=bmBuildUnit'#010+
|
|
|
- ' ',' else if bmBuildUnit in APackage.SupportBuildModes'+
|
|
|
- ' then'#010+
|
|
|
- ' begin'#010+
|
|
|
- ' log(vlInfo,SInfoFallbackBuildmodeBU);'#010+
|
|
|
- ' APackage.FBuildMode:=bmBuildUnit;'#010+
|
|
|
- ' end'#010+
|
|
|
- ' ',' else'#010+
|
|
|
- ' raise exception.create(SErrUnsupportedBuildmode);'+
|
|
|
- #010+
|
|
|
- ' end;'#010+
|
|
|
- ' bmBuildUnit: begin'#010+
|
|
|
+ 'Value);'#013,#010+
|
|
|
+ ' end;'#013#010+
|
|
|
+ ' writeln(F,'#039';'#039');'#013#010+
|
|
|
+ ' writeln(F,'#039'implementation'#039');'#013#010+
|
|
|
+ ' writeln(F,'#039'end.'#039');'#013#010+
|
|
|
+ #013#010+
|
|
|
+ ' system.close(F);'#013#010+
|
|
|
+ #013#010+
|
|
|
+ ' APackage.FBuildMode:=bmOneByOne;'#013#010+
|
|
|
+ ' try'#013#010+
|
|
|
+ ' Compile(APackage,APackage.FBUTarget);',#013#010+
|
|
|
+ ' finally'#013#010+
|
|
|
+ ' // Delete temporary build-unit files'#013#010+
|
|
|
+ ' L := TStringList.Create;'#013#010+
|
|
|
+ ' try'#013#010+
|
|
|
+ ' APackage.FBUTarget.GetCleanFiles(L,IncludeTrailingPathDeli'+
|
|
|
+ 'miter(AddPathPrefix(APackage,APackage.GetUnitsOutput','Dir(Defaults.CPU'+
|
|
|
+ ',Defaults.OS))),'#039#039',Defaults.CPU,Defaults.OS);'#013#010+
|
|
|
+ ' L.Add(AddPathPrefix(APackage,APackage.FBUTarget.SourceFile'+
|
|
|
+ 'Name));'#013#010+
|
|
|
+ ' CmdDeleteFiles(L);'#013#010+
|
|
|
+ ' finally'#013#010+
|
|
|
+ ' L.Free;'#013#010+
|
|
|
+ ' end;'#013#010+
|
|
|
+ ' en','d;'#013#010+
|
|
|
+ ' end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ ' For I:=0 to APackage.Targets.Count-1 do'#013#010+
|
|
|
+ ' begin'#013#010+
|
|
|
+ ' T:=APackage.Targets.TargetItems[i];'#013#010+
|
|
|
+ ' if (T.TargetType = ttUnit) and (TargetOK(T, Defaults.CPU, Defa'+
|
|
|
+ 'ults.OS)) then'#013#010+
|
|
|
+ ' begin'#013#010+
|
|
|
+ ' If A','ssigned(T.AfterCompile) then'#013#010+
|
|
|
+ ' T.AfterCompile(T);'#013#010+
|
|
|
+ ' ExecuteCommands(T.Commands,caAfterCompile);'#013#010+
|
|
|
+ ' end'#013#010+
|
|
|
+ ' end;'#013#010+
|
|
|
+ ' end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ ' procedure ProcessCompileTarget;'#013#010+
|
|
|
+ ' begin'#013#010+
|
|
|
+ ' if TargetOK(T, Defaults.CPU, Defau','lts.OS) then'#013#010+
|
|
|
+ ' begin'#013#010+
|
|
|
+ ' if T.State=tsNeutral then'#013#010+
|
|
|
+ ' MaybeCompile(APackage,T);'#013#010+
|
|
|
+ ' // If a target is compiled, re-generate the UnitConfigFile'#013+
|
|
|
+ #010+
|
|
|
+ ' if T.FTargetState<>tsNoCompile then'#013#010+
|
|
|
+ ' RegenerateUnitconf','igFile:= True;'#013#010+
|
|
|
+ ' end'#013#010+
|
|
|
+ ' else'#013#010+
|
|
|
+ ' begin'#013#010+
|
|
|
+ ' if not(Defaults.CPU in T.CPUs) then'#013#010+
|
|
|
+ ' Log(vldebug, Format(SDbgSkippingTargetWrongCPU, [T.Name, CPU'+
|
|
|
+ 'sToString(T.CPUs)]));'#013#010+
|
|
|
+ ' if not(Defaults.OS in T.OSes) then'#013#010+
|
|
|
+ ' ',' Log(vldebug, Format(SDbgSkippingTargetWrongOS, [T.Name, OS'+
|
|
|
+ 'esToString(T.OSes)]));'#013#010+
|
|
|
+ ' end;'#013#010+
|
|
|
+ ' end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' cmdOpts := '#039#039';'#013#010+
|
|
|
+ #013#010+
|
|
|
+ ' log(vlWarning,SWarnStartCompilingPackage,[APackage.Name, Defaults.Ta'+
|
|
|
+ 'rget]);'#013#010+
|
|
|
+ #013#010+
|
|
|
+ ' case Defaults.BuildMode ','of'#013#010+
|
|
|
+ ' bmOneByOne: begin'#013#010+
|
|
|
+ ' if (bmOneByOne in APackage.SupportBuildModes) then'#013+
|
|
|
+ #010+
|
|
|
+ ' APackage.FBuildMode:=bmBuildUnit'#013#010+
|
|
|
+ ' else if bmBuildUnit in APackage.SupportBuildModes t'+
|
|
|
+ 'hen'#013#010+
|
|
|
+ ' ',' begin'#013#010+
|
|
|
+ ' log(vlInfo,SInfoFallbackBuildmodeBU);'#013#010+
|
|
|
+ ' APackage.FBuildMode:=bmBuildUnit;'#013#010+
|
|
|
+ ' end'#013#010+
|
|
|
+ ' else'#013#010+
|
|
|
+ ' raise exception.create(SErrUnsu','pportedBuildmode'+
|
|
|
+ ');'#013#010+
|
|
|
+ ' end;'#013#010+
|
|
|
+ ' bmBuildUnit: begin'#013#010+
|
|
|
' // When bmBuildUnit is supported by the package use'+
|
|
|
- ' a buildunit.'#010+
|
|
|
- ' // Unles','s there is only one target and bmOneByOne'+
|
|
|
- ' is also supported'#010+
|
|
|
- ' if (bmBuildUnit in APackage.SupportBuildModes) and'#010+
|
|
|
+ ' a buildunit.'#013#010+
|
|
|
+ ' // Unless there is only one target and bmOneByOne i'+
|
|
|
+ 's also supported'#013#010,
|
|
|
+ ' if (bmBuildUnit in APackage.SupportBuildModes) and'#013+
|
|
|
+ #010+
|
|
|
' not ((APackage.Targets.Count=1) and (bmOneByOne '+
|
|
|
- 'in APackage.SupportBuildModes)) then'#010+
|
|
|
- ' ',' APackage.FBuildMode:=bmBuildUnit'#010+
|
|
|
- ' else if bmOneByOne in APackage.SupportBuildModes th'+
|
|
|
- 'en'#010+
|
|
|
- ' begin'#010+
|
|
|
- ' log(vlInfo,SInfoFallbackBuildmode);'#010+
|
|
|
- ' APackag','e.FBuildMode:=bmOneByOne'#010+
|
|
|
- ' end'#010+
|
|
|
- ' else'#010+
|
|
|
+ 'in APackage.SupportBuildModes)) then'#013#010+
|
|
|
+ ' APackage.FBuildMode:=bmBuildUnit'#013#010+
|
|
|
+ ' ',' else if bmOneByOne in APackage.SupportBuildModes '+
|
|
|
+ 'then'#013#010+
|
|
|
+ ' begin'#013#010+
|
|
|
+ ' log(vlInfo,SInfoFallbackBuildmode);'#013#010+
|
|
|
+ ' APackage.FBuildMode:=bmOneByOne'#013#010+
|
|
|
+ ' end'#013#010+
|
|
|
+ ' ',' else'#013#010+
|
|
|
' raise exception.create(SErrUnsupportedBuildmode);'+
|
|
|
- #010+
|
|
|
- ' end;'#010+
|
|
|
- ' end;'#010+
|
|
|
- #010+
|
|
|
- ' GPathPrefix:=APackage.Directory;'#010+
|
|
|
- ' Try'#010+
|
|
|
- ' CreateOutputDir(APac','kage);'#010+
|
|
|
- ' APackage.Dictionary.AddVariable('#039'UNITSOUTPUTDIR'#039',AddPathPr'+
|
|
|
- 'efix(APackage,APackage.GetUnitsOutputDir(Defaults.CPU,Defaults.OS)));'#010+
|
|
|
+ #013#010+
|
|
|
+ ' end;'#013#010+
|
|
|
+ ' end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ ' GPathPrefix:=APackage.Directory;'#013#010+
|
|
|
+ ' Try'#013#010+
|
|
|
+ ' CreateOutputDir(APackage);'#013#010+
|
|
|
+ ' APackage.Dictionary.AddVariable('#039,'UNITSOUTPUTDIR'#039',AddPathP'+
|
|
|
+ 'refix(APackage,APackage.GetUnitsOutputDir(Defaults.CPU,Defaults.OS)));'+
|
|
|
+ #013#010+
|
|
|
' APackage.Dictionary.AddVariable('#039'BINOUTPUTDIR'#039',AddPathPref'+
|
|
|
- 'ix(APackage,APackage.GetBinOutputDir(De','faults.CPU,Defaults.OS)));'#010+
|
|
|
- ' DoBeforeCompile(APackage);'#010+
|
|
|
- ' RegenerateUnitconfigFile:=False;'#010+
|
|
|
- ' if APackage.BuildMode=bmBuildUnit then'#010+
|
|
|
- ' begin'#010+
|
|
|
- ' APackage.FBUTargets := TTargets.Create(TTarget);'#010+
|
|
|
- ' if Defaults.OS in AllLimi','t83fsOses then'#010+
|
|
|
- ' BUName := '#039'BUnit.pp'#039#010+
|
|
|
- ' else'#010+
|
|
|
+ 'ix(APackage,APackage.GetBinOutputDir(Defaults.CPU,Defaults.OS)));'#013#010+
|
|
|
+ ' DoBeforeCom','pile(APackage);'#013#010+
|
|
|
+ ' RegenerateUnitconfigFile:=False;'#013#010+
|
|
|
+ ' if APackage.BuildMode=bmBuildUnit then'#013#010+
|
|
|
+ ' begin'#013#010+
|
|
|
+ ' APackage.FBUTargets := TTargets.Create(TTarget);'#013#010+
|
|
|
+ ' if Defaults.OS in AllLimit83fsOses then'#013#010+
|
|
|
+ ' BUName := '#039,'BUnit.pp'#039#013#010+
|
|
|
+ ' else'#013#010+
|
|
|
' BUName := '#039'BuildUnit_'#039'+StringReplace(APackage.Name,'#039+
|
|
|
- '-'#039','#039'_'#039',[rfReplaceAll])+'#039'.pp'#039';'#010+
|
|
|
- ' APackage.FBUTarget := APackage.FBUTargets.AddUnit(BUName);'#010+
|
|
|
- ' APackage.FBUTa','rget.FTargetSourceFileName := APackage.FBUTarg'+
|
|
|
- 'et.SourceFileName;'#010+
|
|
|
- ' end;'#010+
|
|
|
- ' For I:=0 to APackage.Targets.Count-1 do'#010+
|
|
|
- ' begin'#010+
|
|
|
- ' T:=APackage.Targets.TargetItems[i];'#010+
|
|
|
- ' case T.TargetType of'#010+
|
|
|
- ' ttUnit:'#010+
|
|
|
- ' begin'#010+
|
|
|
- ' ',' ProcessCompileTarget;'#010+
|
|
|
- ' end;'#010+
|
|
|
- ' ttProgram:'#010+
|
|
|
- ' begin // do nothing, are compiled later'#010+
|
|
|
- ' end;'#010+
|
|
|
- ' ttFPDoc:'#010+
|
|
|
- ' begin'#010+
|
|
|
- ' for d := 0 to T.Dependencies.Count - 1 do'#010+
|
|
|
- ' begin'#010+
|
|
|
- ' ',' dep := TDependency(T.Dependencies[d]);'#010+
|
|
|
- #010+
|
|
|
- ' //add unit dependencies'#010+
|
|
|
- ' if dep.DependencyType = depUnit then'#010+
|
|
|
+ '-'#039','#039'_'#039',[rfReplaceAll])+'#039'.pp'#039';'#013#010+
|
|
|
+ ' APackage.FBUTarget := APackage.FBUTargets.AddUnit(BUName);'#013+
|
|
|
+ #010+
|
|
|
+ ' APackage.FBUTarget.FTargetSourceFileName := AP','ackage.FBUTarg'+
|
|
|
+ 'et.SourceFileName;'#013#010+
|
|
|
+ ' end;'#013#010+
|
|
|
+ ' For I:=0 to APackage.Targets.Count-1 do'#013#010+
|
|
|
+ ' begin'#013#010+
|
|
|
+ ' T:=APackage.Targets.TargetItems[i];'#013#010+
|
|
|
+ ' case T.TargetType of'#013#010+
|
|
|
+ ' ttUnit:'#013#010+
|
|
|
+ ' begin'#013#010+
|
|
|
+ ' ProcessCompileT','arget;'#013#010+
|
|
|
+ ' end;'#013#010+
|
|
|
+ ' ttProgram:'#013#010+
|
|
|
+ ' begin // do nothing, are compiled later'#013#010+
|
|
|
+ ' end;'#013#010+
|
|
|
+ ' ttFPDoc:'#013#010+
|
|
|
+ ' begin'#013#010+
|
|
|
+ ' for d := 0 to T.Dependencies.Count - 1 do'#013#010+
|
|
|
+ ' begin'#013#010+
|
|
|
+ ' dep :=',' TDependency(T.Dependencies[d]);'#013#010+
|
|
|
+ #013#010+
|
|
|
+ ' //add unit dependencies'#013#010+
|
|
|
+ ' if dep.DependencyType = depUnit then'#013#010+
|
|
|
' cmdOpts := cmdOpts + '#039' --input='#039' + AddPathPref'+
|
|
|
- 'ix(APackage,dep.Value);'#010+
|
|
|
- ' end;',#010+
|
|
|
- #010+
|
|
|
- ' //check if a documentation target is given'#010+
|
|
|
+ 'ix(APackage,dep.Value);'#013#010+
|
|
|
+ ' end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ ' ',' //check if a documentation target is given'#013#010+
|
|
|
' cmdOpts := cmdOpts + '#039' --input='#039' + AddPathPrefix(A'+
|
|
|
'Package,T.Directory + T.Name + T.Extension) + '#039' --descr='#039'+ T.X'+
|
|
|
- 'ML;'#010+
|
|
|
- ' end'#010+
|
|
|
- ' else'#010+
|
|
|
- ' log(vldebug, SDbgT','argetIsNotAUnitOrProgram,[T.Name]);'#010+
|
|
|
- ' end;'#010+
|
|
|
- ' end;'#010+
|
|
|
- #010+
|
|
|
- ' if APackage.BuildMode=bmBuildUnit then'#010+
|
|
|
- ' CompileBuildUnit;'#010+
|
|
|
- #010+
|
|
|
- ' FreeAndNil(APackage.FBUTarget);'#010+
|
|
|
- #010+
|
|
|
- ' For I:=0 to APackage.Targets.Count-1 do'#010+
|
|
|
- ' begin'#010+
|
|
|
- ' T:=APackag','e.Targets.TargetItems[i];'#010+
|
|
|
- ' if T.TargetType=ttProgram then'#010+
|
|
|
- ' begin'#010+
|
|
|
- ' ProcessCompileTarget;'#010+
|
|
|
- ' end;'#010+
|
|
|
- ' end;'#010+
|
|
|
- #010+
|
|
|
- ' if RegenerateUnitconfigFile then'#010+
|
|
|
- ' begin'#010+
|
|
|
- ' UC:=IncludeTrailingPathDelimiter(AddPathP','refix(APackage,APac'+
|
|
|
+ 'ML;'#013#010+
|
|
|
+ ' end'#013#010+
|
|
|
+ ' else'#013#010+
|
|
|
+ ' log(vldebug, SDbgTarge','tIsNotAUnitOrProgram,[T.Name]);'#013#010+
|
|
|
+ ' end;'#013#010+
|
|
|
+ ' end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ ' if APackage.BuildMode=bmBuildUnit then'#013#010+
|
|
|
+ ' CompileBuildUnit;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ ' FreeAndNil(APackage.FBUTarget);'#013#010+
|
|
|
+ #013#010+
|
|
|
+ ' For I:=0 to APackage.Targets.Count-1 do'#013#010+
|
|
|
+ ' begin'#013#010+
|
|
|
+ ' T:=','APackage.Targets.TargetItems[i];'#013#010+
|
|
|
+ ' if T.TargetType=ttProgram then'#013#010+
|
|
|
+ ' begin'#013#010+
|
|
|
+ ' ProcessCompileTarget;'#013#010+
|
|
|
+ ' end;'#013#010+
|
|
|
+ ' end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ ' if RegenerateUnitconfigFile then'#013#010+
|
|
|
+ ' begin'#013#010+
|
|
|
+ ' UC:=IncludeTrailingPathDe','limiter(AddPathPrefix(APackage,APac'+
|
|
|
'kage.GetUnitConfigOutputDir(Defaults.CPU,Defaults.OS)))+UnitConfigFile'+
|
|
|
- ';'#010+
|
|
|
- ' Log(vlInfo, Format(SDbgGenerating, [UC]));'#010+
|
|
|
- ' APackage.SaveUnitConfigToFile(UC,Defaults.CPU,Defaults.OS);'#010+
|
|
|
- ' end;'#010+
|
|
|
- #010+
|
|
|
- ' //compile docu','mentation, because options were found'#010+
|
|
|
- ' if cmdOpts <> '#039#039' then'#010+
|
|
|
- ' begin'#010+
|
|
|
- ' //append package name'#010+
|
|
|
- ' cmdOpts := cmdOpts + '#039' --package='#039' + APackage.Name;'#010+
|
|
|
- #010+
|
|
|
- ' for IFPDocFormat:=Low(TFPDocFormat) to High(TFPDocFormat) do'#010+
|
|
|
- ' begin'#010,
|
|
|
- ' if IFPDocFormat in APackage.FPDocFormat then'#010+
|
|
|
- ' begin'#010+
|
|
|
- ' //prepend output format'#010+
|
|
|
- ' case IFPDocFormat of'#010+
|
|
|
+ ';'#013#010+
|
|
|
+ ' Log(vlInfo, Format(SDbgGenerating, [UC]));'#013#010+
|
|
|
+ ' APackage.SaveUnitConfigToFile(UC,Defaults.CPU,Defaults.OS);'#013+
|
|
|
+ #010+
|
|
|
+ ' end;'#013,#010+
|
|
|
+ #013#010+
|
|
|
+ ' //compile documentation, because options were found'#013#010+
|
|
|
+ ' if cmdOpts <> '#039#039' then'#013#010+
|
|
|
+ ' begin'#013#010+
|
|
|
+ ' //append package name'#013#010+
|
|
|
+ ' cmdOpts := cmdOpts + '#039' --package='#039' + APackage.Name;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ ' for IFPDocFormat:=Low(TFPDocFormat) to High(TF','PDocFormat) do'#013+
|
|
|
+ #010+
|
|
|
+ ' begin'#013#010+
|
|
|
+ ' if IFPDocFormat in APackage.FPDocFormat then'#013#010+
|
|
|
+ ' begin'#013#010+
|
|
|
+ ' //prepend output format'#013#010+
|
|
|
+ ' case IFPDocFormat of'#013#010+
|
|
|
' ffHtml: sFPDocFormat := '#039'--format=html --output='#039+
|
|
|
- ' + AddPathPrefix(APackage,Defaults.FPDocOu','tputDir);'#010+
|
|
|
+ ' + AddPat','hPrefix(APackage,Defaults.FPDocOutputDir);'#013#010+
|
|
|
' ffHtm: sFPDocFormat := '#039'--format=htm --output='#039+
|
|
|
- ' + AddPathPrefix(APackage,Defaults.FPDocOutputDir);'#010+
|
|
|
+ ' + AddPathPrefix(APackage,Defaults.FPDocOutputDir);'#013#010+
|
|
|
' ffXHtml: sFPDocFormat := '#039'--format=xhtml --output='+
|
|
|
- #039' + AddPathPrefix(APackage,Defaults.FPDocOutput','Dir);'#010+
|
|
|
+ #039' + AddPathP','refix(APackage,Defaults.FPDocOutputDir);'#013#010+
|
|
|
' ffLaTex: sFPDocFormat := '#039'--format=latex --output='+
|
|
|
#039' + AddPathPrefix(APackage,Defaults.FPDocOutputDir) + APackage.Name '+
|
|
|
- '+ '#039'.tex'#039';'#010+
|
|
|
- ' ffXMLStruct: sFPDocFormat := '#039'--format=xml-struct --ou'+
|
|
|
- 'tput='#039' + AddPathPrefix(A','Package,Defaults.FPDocOutputDir);'#010+
|
|
|
+ '+ '#039'.tex'#039';'#013#010+
|
|
|
+ ' ffXMLStruct: sFPDocFormat := '#039'--format=xm','l-struct --'+
|
|
|
+ 'output='#039' + AddPathPrefix(APackage,Defaults.FPDocOutputDir);'#013#010+
|
|
|
' ffChm: sFPDocFormat := '#039'--format=chm --output='#039+
|
|
|
' + AddPathPrefix(APackage,Defaults.FPDocOutputDir) + APackage.Name + '#039+
|
|
|
- '.chm'#039';'#010+
|
|
|
- ' end;'#010+
|
|
|
- #010+
|
|
|
- ' //execute fpdoc'#010+
|
|
|
- ' Cmd:=ExeSear','ch('#039'fpdoc'#039',GetEnvironmentvariable('#039+
|
|
|
- 'PATH'#039'));'#010+
|
|
|
- ' if Cmd = '#039#039' then Cmd := '#039'fpdoc'#039';'#010+
|
|
|
- ' ExecuteProcess(Cmd, sFPDocFormat + cmdOpts);'#010+
|
|
|
- ' end;'#010+
|
|
|
- ' end;'#010+
|
|
|
- ' end;'#010+
|
|
|
- #010+
|
|
|
- ' DoAfterCompile(APackage);'#010+
|
|
|
- ' Finally'#010+
|
|
|
- ' GPathPrefix:='#039#039';'#010+
|
|
|
- ' e','nd;'#010+
|
|
|
- ' inc(FProgressCount);'#010+
|
|
|
- ' if FProgressMax>0 then'#010+
|
|
|
+ '.chm'#039';'#013#010+
|
|
|
+ ' end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ ' ',' //execute fpdoc'#013#010+
|
|
|
+ ' Cmd:=ExeSearch('#039'fpdoc'#039',GetEnvironmentvariable('#039'P'+
|
|
|
+ 'ATH'#039'));'#013#010+
|
|
|
+ ' if Cmd = '#039#039' then Cmd := '#039'fpdoc'#039';'#013#010+
|
|
|
+ ' ExecuteProcess(Cmd, sFPDocFormat + cmdOpts);'#013#010+
|
|
|
+ ' end;'#013#010+
|
|
|
+ ' end;'#013#010+
|
|
|
+ ' end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ ' DoAfterComp','ile(APackage);'#013#010+
|
|
|
+ ' Finally'#013#010+
|
|
|
+ ' GPathPrefix:='#039#039';'#013#010+
|
|
|
+ ' end;'#013#010+
|
|
|
+ ' inc(FProgressCount);'#013#010+
|
|
|
+ ' if FProgressMax>0 then'#013#010+
|
|
|
' log(vlWarning,SWarnCompilingPackagecompleteProgress,[(FProgressCou'+
|
|
|
- 'nt)/FProgressMax * 100, APackage.Name])'#010+
|
|
|
- ' else'#010+
|
|
|
- ' log(vlWarning,SWarnCompilingPackagecomplete,[APackage.Name]);'#010+
|
|
|
- 'end;'#010,
|
|
|
- #010+
|
|
|
- 'procedure TBuildEngine.MaybeCompile(APackage: TPackage);'#010+
|
|
|
- 'begin'#010+
|
|
|
- ' if ReadyToCompile(APackage) then'#010+
|
|
|
- ' begin'#010+
|
|
|
- ' Compile(APackage);'#010+
|
|
|
- ' APackage.FTargetState:=tsCompiled;'#010+
|
|
|
- ' end;'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
- 'function TBuildEngine.ReadyToCompile(APackage: TPa','ckage) : Boolean;'#010+
|
|
|
- 'begin'#010+
|
|
|
- ' result := False;'#010+
|
|
|
- ' if APackage.State in [tsCompiled, tsNoCompile] then'#010+
|
|
|
- ' begin'#010+
|
|
|
- ' Log(vlInfo,SInfoPackageAlreadyProcessed,[APackage.Name]);'#010+
|
|
|
- ' Exit;'#010+
|
|
|
- ' end;'#010+
|
|
|
- ' if APackage.State<>tsNeutral then'#010+
|
|
|
- ' Error(SE','rrInvalidState,[APackage.Name]);'#010+
|
|
|
- ' Log(vlDebug,SDbgConsideringPackage,[APackage.Name]);'#010+
|
|
|
- ' LogIndent;'#010+
|
|
|
- ' if Defaults.ThreadsAmount=-1 then'#010+
|
|
|
- ' APackage.FTargetState:=tsConsidering;'#010+
|
|
|
- ' ResolveDependencies(APackage.Dependencies,(APackage.Collect','ion as '+
|
|
|
- 'TPackages));'#010+
|
|
|
+ 'nt)/FProgressMax * 100, APackage.Name])'#013#010+
|
|
|
+ ' else'#013#010+
|
|
|
+ ' log(vlWarn','ing,SWarnCompilingPackagecomplete,[APackage.Name]);'#013+
|
|
|
+ #010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ 'procedure TBuildEngine.MaybeCompile(APackage: TPackage);'#013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' if ReadyToCompile(APackage) then'#013#010+
|
|
|
+ ' begin'#013#010+
|
|
|
+ ' Compile(APackage);'#013#010+
|
|
|
+ ' APackage.FTargetState:=tsCompiled;'#013,#010+
|
|
|
+ ' end;'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ 'function TBuildEngine.ReadyToCompile(APackage: TPackage) : Boolean;'#013+
|
|
|
+ #010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' result := False;'#013#010+
|
|
|
+ ' if APackage.State in [tsCompiled, tsNoCompile] then'#013#010+
|
|
|
+ ' begin'#013#010+
|
|
|
+ ' Log(vlInfo,SInfoPackageAlreadyProcessed,[APackage.Nam','e]);'#013#010+
|
|
|
+ ' Exit;'#013#010+
|
|
|
+ ' end;'#013#010+
|
|
|
+ ' if APackage.State<>tsNeutral then'#013#010+
|
|
|
+ ' Error(SErrInvalidState,[APackage.Name]);'#013#010+
|
|
|
+ ' Log(vlDebug,SDbgConsideringPackage,[APackage.Name]);'#013#010+
|
|
|
+ ' LogIndent;'#013#010+
|
|
|
+ ' if Defaults.ThreadsAmount=-1 then'#013#010+
|
|
|
+ ' APackage.FTargetS','tate:=tsConsidering;'#013#010+
|
|
|
+ ' ResolveDependencies(APackage.Dependencies,(APackage.Collection as TP'+
|
|
|
+ 'ackages));'#013#010+
|
|
|
' // When multiple threads are used, delay the compilation of the pack'+
|
|
|
- 'age when'#010+
|
|
|
- ' // there are unsolved dependencies. When no threads are used, compil'+
|
|
|
- 'e all'#010+
|
|
|
- ' // dependencies.'#010+
|
|
|
- ' if Defaults.ThreadsAmount=-1 then'#010+
|
|
|
- ' Compil','eDependencies(APackage)'#010+
|
|
|
- ' else if CheckDependencies(APackage)=cdNotYetAvailable then'#010+
|
|
|
- ' begin'#010+
|
|
|
- ' log(vlInfo,'#039'Delaying package '#039'+apackage.name);'#010+
|
|
|
- ' result := False;'#010+
|
|
|
- ' Exit;'#010+
|
|
|
- ' end;'#010+
|
|
|
- ' APackage.SetDefaultPackageVariant;'#010+
|
|
|
- #010+
|
|
|
- ' ResolveF','ileNames(APackage,Defaults.CPU,Defaults.OS,True,False);'#010+
|
|
|
- ' If NeedsCompile(APackage) then'#010+
|
|
|
- ' result := True'#010+
|
|
|
- ' else'#010+
|
|
|
- ' begin'#010+
|
|
|
- ' APackage.FTargetState:=tsNoCompile;'#010+
|
|
|
- ' inc(FProgressCount);'#010+
|
|
|
- ' end;'#010+
|
|
|
- ' LogUnIndent;'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
- #010+
|
|
|
- 'Function TBuild','Engine.InstallPackageFiles(APAckage : TPackage; tt : '+
|
|
|
- 'TTargetTypes; Const Dest : String):Boolean;'#010+
|
|
|
- 'Var'#010+
|
|
|
- ' List : TStringList;'#010+
|
|
|
- 'begin'#010+
|
|
|
- ' Result:=False;'#010+
|
|
|
- ' List:=TStringList.Create;'#010+
|
|
|
- ' Try'#010+
|
|
|
- ' APackage.GetInstallFiles(List,tt,Defaults.CPU, Defaults.','OS);'#010+
|
|
|
- ' if (List.Count>0) then'#010+
|
|
|
- ' begin'#010+
|
|
|
- ' Result:=True;'#010+
|
|
|
- ' CmdCopyFiles(List,Dest);'#010+
|
|
|
- ' end;'#010+
|
|
|
- ' Finally'#010+
|
|
|
- ' List.Free;'#010+
|
|
|
- ' end;'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
+ 'age when'#013#010+
|
|
|
+ ' // there are unsolved dependencies. When no threads ar','e used, comp'+
|
|
|
+ 'ile all'#013#010+
|
|
|
+ ' // dependencies.'#013#010+
|
|
|
+ ' if Defaults.ThreadsAmount=-1 then'#013#010+
|
|
|
+ ' CompileDependencies(APackage)'#013#010+
|
|
|
+ ' else if CheckDependencies(APackage)=cdNotYetAvailable then'#013#010+
|
|
|
+ ' begin'#013#010+
|
|
|
+ ' log(vlInfo,'#039'Delaying package '#039'+apackage.name);'#013#010,
|
|
|
+ ' result := False;'#013#010+
|
|
|
+ ' Exit;'#013#010+
|
|
|
+ ' end;'#013#010+
|
|
|
+ ' APackage.SetDefaultPackageVariant;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ ' ResolveFileNames(APackage,Defaults.CPU,Defaults.OS,True,False);'#013#010+
|
|
|
+ ' If NeedsCompile(APackage) then'#013#010+
|
|
|
+ ' result := True'#013#010+
|
|
|
+ ' else'#013#010+
|
|
|
+ ' begin'#013#010+
|
|
|
+ ' APackag','e.FTargetState:=tsNoCompile;'#013#010+
|
|
|
+ ' inc(FProgressCount);'#013#010+
|
|
|
+ ' end;'#013#010+
|
|
|
+ ' LogUnIndent;'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ #013#010+
|
|
|
+ 'Function TBuildEngine.InstallPackageFiles(APAckage : TPackage; tt : TT'+
|
|
|
+ 'argetTypes; Const Dest : String):Boolean;'#013#010+
|
|
|
+ 'Var'#013#010+
|
|
|
+ ' List : TStringList;'#013#010+
|
|
|
+ 'begin',#013#010+
|
|
|
+ ' Result:=False;'#013#010+
|
|
|
+ ' List:=TStringList.Create;'#013#010+
|
|
|
+ ' Try'#013#010+
|
|
|
+ ' APackage.GetInstallFiles(List,tt,Defaults.CPU, Defaults.OS);'#013#010+
|
|
|
+ ' if (List.Count>0) then'#013#010+
|
|
|
+ ' begin'#013#010+
|
|
|
+ ' Result:=True;'#013#010+
|
|
|
+ ' CmdCopyFiles(List,Dest);'#013#010+
|
|
|
+ ' end;'#013#010+
|
|
|
+ ' Finall','y'#013#010+
|
|
|
+ ' List.Free;'#013#010+
|
|
|
+ ' end;'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
'procedure TBuildEngine.InstallUnitConfigFile(APAckage: TPackage; const'+
|
|
|
- ' Dest: String);'#010+
|
|
|
- 'Var'#010+
|
|
|
- ' ','List : TStringList;'#010+
|
|
|
- 'begin'#010+
|
|
|
- ' List:=TStringList.Create;'#010+
|
|
|
- ' Try'#010+
|
|
|
- ' List.add(IncludeTrailingPathDelimiter(APackage.GetUnitConfigOutput'+
|
|
|
- 'Dir(Defaults.CPU,Defaults.OS))+UnitConfigFile);'#010+
|
|
|
- ' CmdCopyFiles(List,Dest);'#010+
|
|
|
- ' Finally'#010+
|
|
|
- ' List.Free;'#010+
|
|
|
- ' end;'#010+
|
|
|
- 'e','nd;'#010+
|
|
|
- #010+
|
|
|
+ ' Dest: String);'#013#010+
|
|
|
+ 'Var'#013#010+
|
|
|
+ ' List : TStringList;'#013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' List:=TStringList.Create;'#013#010+
|
|
|
+ ' Try'#013#010+
|
|
|
+ ' List.add(IncludeTrailingPathDelimiter(APack','age.GetUnitConfigOutp'+
|
|
|
+ 'utDir(Defaults.CPU,Defaults.OS))+UnitConfigFile);'#013#010+
|
|
|
+ ' CmdCopyFiles(List,Dest);'#013#010+
|
|
|
+ ' Finally'#013#010+
|
|
|
+ ' List.Free;'#013#010+
|
|
|
+ ' end;'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
'function TBuildEngine.InstallPackageSourceFiles(APAckage : TPackage; s'+
|
|
|
- 'tt : TSourceTypes; ttt : TTargetTypes; Const Dest : String): Boolean;'#010+
|
|
|
- 'Var'#010+
|
|
|
- ' List : TStringList;'#010+
|
|
|
- 'begin'#010+
|
|
|
- ' Result:=False;'#010+
|
|
|
- ' List:=TStringList.Create;'#010+
|
|
|
- ' Try'#010+
|
|
|
- ' APackage','.GetInstallSourceFiles(List,stt,ttt);'#010+
|
|
|
- ' if (List.Count>0) then'#010+
|
|
|
- ' begin'#010+
|
|
|
- ' Result:=True;'#010+
|
|
|
- ' CmdCopyFiles(List,Dest);'#010+
|
|
|
- ' end;'#010+
|
|
|
- ' Finally'#010+
|
|
|
- ' List.Free;'#010+
|
|
|
- ' end;'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
- #010+
|
|
|
- 'procedure TBuildEngine.DoBeforeInstall(APackage: TPackage)',';'#010+
|
|
|
- 'begin'#010+
|
|
|
- ' ExecuteCommands(APackage.Commands,caBeforeInstall);'#010+
|
|
|
- ' If Assigned(APackage.BeforeInstall) then'#010+
|
|
|
- ' APackage.BeforeInstall(APackage);'#010+
|
|
|
- ' If Assigned(APackage.BeforeInstallProc) then'#010+
|
|
|
- ' APackage.BeforeInstallProc(APackage);'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
- #010+
|
|
|
- 'p','rocedure TBuildEngine.DoAfterInstall(APackage: TPackage);'#010+
|
|
|
- 'begin'#010+
|
|
|
- ' If Assigned(APackage.AfterInstall) then'#010+
|
|
|
- ' APackage.AfterInstall(APackage);'#010+
|
|
|
- ' If Assigned(APackage.AfterInstallProc) then'#010+
|
|
|
- ' APackage.AfterInstallProc(APackage);'#010+
|
|
|
- ' ExecuteC','ommands(APackage.Commands,caAfterInstall);'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
- #010+
|
|
|
- 'procedure TBuildEngine.Install(APackage: TPackage);'#010+
|
|
|
- 'Var'#010+
|
|
|
- ' UC,D : String;'#010+
|
|
|
- ' B : Boolean;'#010+
|
|
|
- 'begin'#010+
|
|
|
- ' If (Apackage.State<>tsCompiled) then'#010+
|
|
|
- ' MaybeCompile(APackage);'#010+
|
|
|
- ' try'#010+
|
|
|
- ' Log(vlCommand,SInfo','InstallingPackage,[APackage.Name]);'#010+
|
|
|
- ' If (APackage.Directory<>'#039#039') then'#010+
|
|
|
- ' EnterDir(APackage.Directory);'#010+
|
|
|
- ' DoBeforeInstall(APackage);'#010+
|
|
|
- ' // units'#010+
|
|
|
- ' B:=false;'#010+
|
|
|
+ 'tt : TSourceTypes; ttt : ','TTargetTypes; Const Dest : String): Boolean'+
|
|
|
+ ';'#013#010+
|
|
|
+ 'Var'#013#010+
|
|
|
+ ' List : TStringList;'#013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' Result:=False;'#013#010+
|
|
|
+ ' List:=TStringList.Create;'#013#010+
|
|
|
+ ' Try'#013#010+
|
|
|
+ ' APackage.GetInstallSourceFiles(List,stt,ttt);'#013#010+
|
|
|
+ ' if (List.Count>0) then'#013#010+
|
|
|
+ ' begin'#013#010+
|
|
|
+ ' Resul','t:=True;'#013#010+
|
|
|
+ ' CmdCopyFiles(List,Dest);'#013#010+
|
|
|
+ ' end;'#013#010+
|
|
|
+ ' Finally'#013#010+
|
|
|
+ ' List.Free;'#013#010+
|
|
|
+ ' end;'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ #013#010+
|
|
|
+ 'procedure TBuildEngine.DoBeforeInstall(APackage: TPackage);'#013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' ExecuteCommands(APackage.Commands,caBeforeInstall);'#013#010+
|
|
|
+ ' If Assigned(AP','ackage.BeforeInstall) then'#013#010+
|
|
|
+ ' APackage.BeforeInstall(APackage);'#013#010+
|
|
|
+ ' If Assigned(APackage.BeforeInstallProc) then'#013#010+
|
|
|
+ ' APackage.BeforeInstallProc(APackage);'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ #013#010+
|
|
|
+ 'procedure TBuildEngine.DoAfterInstall(APackage: TPackage);'#013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' If ','Assigned(APackage.AfterInstall) then'#013#010+
|
|
|
+ ' APackage.AfterInstall(APackage);'#013#010+
|
|
|
+ ' If Assigned(APackage.AfterInstallProc) then'#013#010+
|
|
|
+ ' APackage.AfterInstallProc(APackage);'#013#010+
|
|
|
+ ' ExecuteCommands(APackage.Commands,caAfterInstall);'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ #013#010+
|
|
|
+ 'procedure T','BuildEngine.Install(APackage: TPackage);'#013#010+
|
|
|
+ 'Var'#013#010+
|
|
|
+ ' UC,D : String;'#013#010+
|
|
|
+ ' B : Boolean;'#013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' If (Apackage.State<>tsCompiled) then'#013#010+
|
|
|
+ ' MaybeCompile(APackage);'#013#010+
|
|
|
+ ' try'#013#010+
|
|
|
+ ' Log(vlCommand,SInfoInstallingPackage,[APackage.Name]);'#013#010+
|
|
|
+ ' If (APackage','.Directory<>'#039#039') then'#013#010+
|
|
|
+ ' EnterDir(APackage.Directory);'#013#010+
|
|
|
+ ' DoBeforeInstall(APackage);'#013#010+
|
|
|
+ ' // units'#013#010+
|
|
|
+ ' B:=false;'#013#010+
|
|
|
' GlobalDictionary.AddVariable('#039'PackageName'#039',APackage.Name);'+
|
|
|
- #010+
|
|
|
- ' Global','Dictionary.AddVariable('#039'unitinstalldir'#039',Defaults.U'+
|
|
|
- 'nitInstallDir);'#010+
|
|
|
+ #013#010+
|
|
|
+ ' GlobalDictionary.AddVariable('#039'unitinstalldir'#039',Defaul','ts.U'+
|
|
|
+ 'nitInstallDir);'#013#010+
|
|
|
' GlobalDictionary.AddVariable('#039'packageunitinstalldir'#039',APack'+
|
|
|
- 'age.GetPackageUnitInstallDir(Defaults.CPU,Defaults.OS));'#010+
|
|
|
- #010+
|
|
|
- ' D:=IncludeTrailingPathDelimiter(Defaults.BaseInsta','llDir);'#010+
|
|
|
- ' // This is to install the TPackage.Installfiles, which are not rel'+
|
|
|
- 'ated to any'#010+
|
|
|
- ' // target'#010+
|
|
|
- ' if InstallPackageFiles(APackage,[],D) then'#010+
|
|
|
- ' B:=true;'#010+
|
|
|
+ 'age.GetPackageUnitInstallDir(Defaults.CPU,Defaults.OS));'#013#010+
|
|
|
+ #013#010+
|
|
|
+ ' D:=IncludeTrailingPathDelimiter(Defaults.BaseInstallDir);'#013#010+
|
|
|
+ ' // This is to install the TPac','kage.Installfiles, which are not r'+
|
|
|
+ 'elated to any'#013#010+
|
|
|
+ ' // target'#013#010+
|
|
|
+ ' if InstallPackageFiles(APackage,[],D) then'#013#010+
|
|
|
+ ' B:=true;'#013#010+
|
|
|
' D:=IncludeTrailingPathDelimiter(Defaults.UnitInstallDir)+APackage.'+
|
|
|
- 'GetP','ackageUnitInstallDir(Defaults.CPU,Defaults.OS);'#010+
|
|
|
- ' if InstallPackageFiles(APackage,[ttUnit, ttImplicitUnit],D) then'#010+
|
|
|
- ' B:=true;'#010+
|
|
|
+ 'GetPackageUnitInstallDir(Defaults.CPU,Defa','ults.OS);'#013#010+
|
|
|
+ ' if InstallPackageFiles(APackage,[ttUnit, ttImplicitUnit],D) then'#013+
|
|
|
+ #010+
|
|
|
+ ' B:=true;'#013#010+
|
|
|
' // By default do not install the examples. Maybe add an option for'+
|
|
|
- ' this later'#010+
|
|
|
- ' //if InstallPackageFil','es(APAckage,ttExampleUnit,D) then'#010+
|
|
|
- ' // B:=true;'#010+
|
|
|
- ' // Unit (dependency) configuration if there were units installed'#010+
|
|
|
- ' D:=IncludeTrailingPathDelimiter(Defaults.UnitInstallDir);'#010+
|
|
|
- ' if B then'#010+
|
|
|
- ' InstallUnitConfigFile(APackage,D);'#010+
|
|
|
- ' ',' // Programs'#010+
|
|
|
- ' D:=IncludeTrailingPathDelimiter(Defaults.BinInstallDir);'#010+
|
|
|
- ' InstallPackageFiles(APAckage,[ttProgram],D);'#010+
|
|
|
- ' //InstallPackageFiles(APAckage,ttExampleProgram,D);'#010+
|
|
|
- ' // Documentation'#010+
|
|
|
- ' D:=IncludeTrailingPathDelimiter(Defa','ults.DocInstallDir)+'#039'fpc'+
|
|
|
- '-'#039'+APackage.FileName+PathDelim;'#010+
|
|
|
- ' InstallPackageSourceFiles(APackage,[stDoc],[],D);'#010+
|
|
|
- ' // Examples'#010+
|
|
|
- ' if Defaults.InstallExamples then'#010+
|
|
|
- ' begin'#010+
|
|
|
- ' D:=IncludeTrailingPathDelimiter(Defaults.ExamplesInstallD','ir)'+
|
|
|
- '+'#039'fpc-'#039'+APackage.FileName+PathDelim+'#039'examples'#039'+PathDel'+
|
|
|
- 'im;'#010+
|
|
|
+ ' this later'#013#010+
|
|
|
+ ' //if InstallPackageFiles(APAckage,ttExampleUnit,D) then'#013,#010+
|
|
|
+ ' // B:=true;'#013#010+
|
|
|
+ ' // Unit (dependency) configuration if there were units installed'#013+
|
|
|
+ #010+
|
|
|
+ ' D:=IncludeTrailingPathDelimiter(Defaults.UnitInstallDir);'#013#010+
|
|
|
+ ' if B then'#013#010+
|
|
|
+ ' InstallUnitConfigFile(APackage,D);'#013#010+
|
|
|
+ ' // Programs'#013#010+
|
|
|
+ ' D:=Include','TrailingPathDelimiter(Defaults.BinInstallDir);'#013#010+
|
|
|
+ ' InstallPackageFiles(APAckage,[ttProgram],D);'#013#010+
|
|
|
+ ' //InstallPackageFiles(APAckage,ttExampleProgram,D);'#013#010+
|
|
|
+ ' // Documentation'#013#010+
|
|
|
+ ' D:=IncludeTrailingPathDelimiter(Defaults.DocInstallDir)+'#039'fp','c'+
|
|
|
+ '-'#039'+APackage.FileName+PathDelim;'#013#010+
|
|
|
+ ' InstallPackageSourceFiles(APackage,[stDoc],[],D);'#013#010+
|
|
|
+ ' // Examples'#013#010+
|
|
|
+ ' if Defaults.InstallExamples then'#013#010+
|
|
|
+ ' begin'#013#010+
|
|
|
+ ' D:=IncludeTrailingPathDelimiter(Defaults.ExamplesInstallDir)+'#039+
|
|
|
+ 'fpc-'#039'+APackag','e.FileName+PathDelim+'#039'examples'#039'+PathDelim;'#013+
|
|
|
+ #010+
|
|
|
' InstallPackageSourceFiles(APackage,[stExample],[ttExampleProgr'+
|
|
|
- 'am,ttExampleUnit],D);'#010+
|
|
|
- ' end;'#010+
|
|
|
- ' // Done.'#010+
|
|
|
- ' APackage.FTargetState:=tsInstalled;'#010+
|
|
|
- ' DoAfterInstall(APac','kage);'#010+
|
|
|
- ' Finally'#010+
|
|
|
- ' If (APackage.Directory<>'#039#039') then'#010+
|
|
|
- ' EnterDir('#039#039');'#010+
|
|
|
- ' end;'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
- #010+
|
|
|
- 'procedure TBuildEngine.DoBeforeArchive(APackage: TPackage);'#010+
|
|
|
- 'begin'#010+
|
|
|
- ' ExecuteCommands(APackage.Commands,caBeforeArchive);'#010+
|
|
|
- ' If Assigned(APackage.BeforeArc','hive) then'#010+
|
|
|
- ' APackage.BeforeArchive(APackage);'#010+
|
|
|
- ' If Assigned(APackage.BeforeArchiveProc) then'#010+
|
|
|
- ' APackage.BeforeArchiveProc(APackage);'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
- #010+
|
|
|
- 'procedure TBuildEngine.DoAfterArchive(APackage: TPackage);'#010+
|
|
|
- 'begin'#010+
|
|
|
- ' If Assigned(APackage.AfterAr','chive) then'#010+
|
|
|
- ' APackage.AfterArchive(APackage);'#010+
|
|
|
- ' If Assigned(APackage.AfterArchiveProc) then'#010+
|
|
|
- ' APackage.AfterArchiveProc(APackage);'#010+
|
|
|
- ' ExecuteCommands(APackage.Commands,caAfterArchive);'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
- #010+
|
|
|
- 'procedure TBuildEngine.Archive(APackage: TPa','ckage);'#010+
|
|
|
- 'Var'#010+
|
|
|
- ' L : TStringList;'#010+
|
|
|
- ' A : String;'#010+
|
|
|
- ' i: integer;'#010+
|
|
|
- ' ICPU : TCPU;'#010+
|
|
|
- ' IOS : TOS;'#010+
|
|
|
- 'begin'#010+
|
|
|
- ' A:=FStartDir+ APackage.FileName + ZipExt;'#010+
|
|
|
- ' Log(vlInfo,SInfoArchivingPackage,[APackage.Name,A]);'#010+
|
|
|
- ' try'#010+
|
|
|
- ' If (APackage.Directory<>'#039#039') then'#010+
|
|
|
- ' ',' EnterDir(APackage.Directory);'#010+
|
|
|
- ' DoBeforeArchive(Apackage);'#010+
|
|
|
- ' L:=TStringList.Create;'#010+
|
|
|
- ' L.Sorted:=true;'#010+
|
|
|
- ' L.Duplicates:=dupIgnore;'#010+
|
|
|
- ' Try'#010+
|
|
|
- ' // Add fpmake.pp & manifest.xml always'#010+
|
|
|
- ' L.Add(FPMakePPFile);'#010+
|
|
|
- ' L.Add(ManifestF','ile);'#010+
|
|
|
- ' //get all files from all targets'#010+
|
|
|
- ' for ICPU:=Low(TCPU) to high(TCPU) do'#010+
|
|
|
- ' for IOS:=Low(TOS) to high(TOS) do'#010+
|
|
|
- ' if OSCPUSupported[IOS,ICPU] then'#010+
|
|
|
- ' begin'#010+
|
|
|
- ' ResolveFileNames(APackage,ICPU,IOS,','false);'#010+
|
|
|
- ' APackage.GetArchiveFiles(L, ICPU, IOS);'#010+
|
|
|
- ' end;'#010+
|
|
|
- ' //from sources'#010+
|
|
|
- ' APackage.GetArchiveSourceFiles(L);'#010+
|
|
|
- #010+
|
|
|
- ' //show all files'#010+
|
|
|
- ' for i := 0 to L.Count-1 do'#010+
|
|
|
- ' Log(vlDebug, Format(SDbgArchivingF','ile, [L[i]]));'#010+
|
|
|
- #010+
|
|
|
- '{$ifdef HAS_UNIT_ZIPPER}'#010+
|
|
|
- ' if not Assigned(ArchiveFilesProc) then'#010+
|
|
|
- ' begin'#010+
|
|
|
- ' FZipFile := TZipper.Create;'#010+
|
|
|
- ' FZipFile.ZipFiles(A, L);'#010+
|
|
|
- ' end'#010+
|
|
|
- ' else'#010+
|
|
|
- '{$endif HAS_UNIT_ZIPPER}'#010+
|
|
|
- ' CmdArchiveF','iles(L,A);'#010+
|
|
|
- ' Finally'#010+
|
|
|
- ' L.Free;'#010+
|
|
|
- #010+
|
|
|
- '{$ifdef HAS_UNIT_ZIPPER}'#010+
|
|
|
- ' if not Assigned(ArchiveFilesProc) then'#010+
|
|
|
- ' FreeAndNil(FZipFile);'#010+
|
|
|
- '{$endif HAS_UNIT_ZIPPER}'#010+
|
|
|
- ' end;'#010+
|
|
|
- ' DoAfterArchive(Apackage);'#010+
|
|
|
- ' Finally'#010+
|
|
|
- ' If (APackage.Directory<>',#039#039') then'#010+
|
|
|
- ' EnterDir('#039#039');'#010+
|
|
|
- ' end;'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
- #010+
|
|
|
- 'procedure TBuildEngine.DoBeforeClean(APackage: TPackage);'#010+
|
|
|
- 'begin'#010+
|
|
|
- ' ExecuteCommands(APackage.Commands,caBeforeClean);'#010+
|
|
|
- ' If Assigned(APackage.BeforeClean) then'#010+
|
|
|
- ' APackage.BeforeClean(APackage);'#010+
|
|
|
- ' If',' Assigned(APackage.BeforeCleanProc) then'#010+
|
|
|
- ' APackage.BeforeCleanProc(APackage);'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
- #010+
|
|
|
- 'procedure TBuildEngine.DoAfterClean(APackage: TPackage);'#010+
|
|
|
- 'begin'#010+
|
|
|
- ' If Assigned(APackage.AfterClean) then'#010+
|
|
|
- ' APackage.AfterClean(APackage);'#010+
|
|
|
- ' If Assigned(','APackage.AfterInstallProc) then'#010+
|
|
|
- ' APackage.AfterCleanProc(APackage);'#010+
|
|
|
- ' ExecuteCommands(APackage.Commands,caAfterClean);'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
- #010+
|
|
|
- 'procedure TBuildEngine.Clean(APackage: TPackage; AllTargets: boolean);'+
|
|
|
- #010+
|
|
|
- 'var'#010+
|
|
|
- ' ACPU: TCpu;'#010+
|
|
|
- ' AOS: TOS;'#010+
|
|
|
- ' Director','yList : TStringList;'#010+
|
|
|
- 'begin'#010+
|
|
|
- ' Log(vlInfo,SInfoCleaningPackage,[APackage.Name]);'#010+
|
|
|
- ' try'#010+
|
|
|
- ' If (APackage.Directory<>'#039#039') then'#010+
|
|
|
- ' EnterDir(APackage.Directory);'#010+
|
|
|
- ' DoBeforeClean(Apackage);'#010+
|
|
|
- ' if AllTargets then'#010+
|
|
|
- ' begin'#010+
|
|
|
- ' // Remove ','the unit-and bin-directories completely. This is s'+
|
|
|
- 'afer in case of files'#010+
|
|
|
- ' // being renamed and such. See also bug 19655'#010+
|
|
|
- ' DirectoryList := TStringList.Create;'#010+
|
|
|
- ' try'#010+
|
|
|
- ' for ACPU:=low(TCpu) to high(TCpu) do'#010+
|
|
|
- ' ',' for AOS:=low(TOS) to high(TOS) do'#010+
|
|
|
- ' begin'#010+
|
|
|
- ' DirectoryList.Add(ExtractFileDir(APackage.GetUnitsOutp'+
|
|
|
- 'utDir(ACPU,AOS)));'#010+
|
|
|
+ 'am,ttExampleUnit],D);'#013#010+
|
|
|
+ ' end;'#013#010+
|
|
|
+ ' // Done.'#013#010+
|
|
|
+ ' APackage.FTargetState:=tsInstalled;'#013#010+
|
|
|
+ ' DoAfterInstall(APackage);'#013#010+
|
|
|
+ ' Fin','ally'#013#010+
|
|
|
+ ' If (APackage.Directory<>'#039#039') then'#013#010+
|
|
|
+ ' EnterDir('#039#039');'#013#010+
|
|
|
+ ' end;'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ #013#010+
|
|
|
+ 'procedure TBuildEngine.DoBeforeArchive(APackage: TPackage);'#013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' ExecuteCommands(APackage.Commands,caBeforeArchive);'#013#010+
|
|
|
+ ' If Assigned(APackage.BeforeArchi','ve) then'#013#010+
|
|
|
+ ' APackage.BeforeArchive(APackage);'#013#010+
|
|
|
+ ' If Assigned(APackage.BeforeArchiveProc) then'#013#010+
|
|
|
+ ' APackage.BeforeArchiveProc(APackage);'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ #013#010+
|
|
|
+ 'procedure TBuildEngine.DoAfterArchive(APackage: TPackage);'#013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' If Assigned(APackage.','AfterArchive) then'#013#010+
|
|
|
+ ' APackage.AfterArchive(APackage);'#013#010+
|
|
|
+ ' If Assigned(APackage.AfterArchiveProc) then'#013#010+
|
|
|
+ ' APackage.AfterArchiveProc(APackage);'#013#010+
|
|
|
+ ' ExecuteCommands(APackage.Commands,caAfterArchive);'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ #013#010+
|
|
|
+ 'procedure TBuildEngine.Archiv','e(APackage: TPackage);'#013#010+
|
|
|
+ 'Var'#013#010+
|
|
|
+ ' L : TStringList;'#013#010+
|
|
|
+ ' A : String;'#013#010+
|
|
|
+ ' i: integer;'#013#010+
|
|
|
+ ' ICPU : TCPU;'#013#010+
|
|
|
+ ' IOS : TOS;'#013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' A:=FStartDir+ APackage.FileName + ZipExt;'#013#010+
|
|
|
+ ' Log(vlInfo,SInfoArchivingPackage,[APackage.Name,A]);'#013#010+
|
|
|
+ ' try'#013#010+
|
|
|
+ ' If (APackag','e.Directory<>'#039#039') then'#013#010+
|
|
|
+ ' EnterDir(APackage.Directory);'#013#010+
|
|
|
+ ' DoBeforeArchive(Apackage);'#013#010+
|
|
|
+ ' L:=TStringList.Create;'#013#010+
|
|
|
+ ' L.Sorted:=true;'#013#010+
|
|
|
+ ' L.Duplicates:=dupIgnore;'#013#010+
|
|
|
+ ' Try'#013#010+
|
|
|
+ ' // Add fpmake.pp & manifest.xml always'#013#010+
|
|
|
+ ' L.Add(FP','MakePPFile);'#013#010+
|
|
|
+ ' L.Add(ManifestFile);'#013#010+
|
|
|
+ ' //get all files from all targets'#013#010+
|
|
|
+ ' for ICPU:=Low(TCPU) to high(TCPU) do'#013#010+
|
|
|
+ ' for IOS:=Low(TOS) to high(TOS) do'#013#010+
|
|
|
+ ' if OSCPUSupported[IOS,ICPU] then'#013#010+
|
|
|
+ ' begin'#013#010+
|
|
|
+ ' ',' ResolveFileNames(APackage,ICPU,IOS,false);'#013#010+
|
|
|
+ ' APackage.GetArchiveFiles(L, ICPU, IOS);'#013#010+
|
|
|
+ ' end;'#013#010+
|
|
|
+ ' //from sources'#013#010+
|
|
|
+ ' APackage.GetArchiveSourceFiles(L);'#013#010+
|
|
|
+ #013#010+
|
|
|
+ ' //show all files'#013#010+
|
|
|
+ ' for i := 0 to L.Count','-1 do'#013#010+
|
|
|
+ ' Log(vlDebug, Format(SDbgArchivingFile, [L[i]]));'#013#010+
|
|
|
+ #013#010+
|
|
|
+ '{$ifdef HAS_UNIT_ZIPPER}'#013#010+
|
|
|
+ ' if not Assigned(ArchiveFilesProc) then'#013#010+
|
|
|
+ ' begin'#013#010+
|
|
|
+ ' FZipFile := TZipper.Create;'#013#010+
|
|
|
+ ' FZipFile.ZipFiles(A, L);'#013#010+
|
|
|
+ ' end',#013#010+
|
|
|
+ ' else'#013#010+
|
|
|
+ '{$endif HAS_UNIT_ZIPPER}'#013#010+
|
|
|
+ ' CmdArchiveFiles(L,A);'#013#010+
|
|
|
+ ' Finally'#013#010+
|
|
|
+ ' L.Free;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ '{$ifdef HAS_UNIT_ZIPPER}'#013#010+
|
|
|
+ ' if not Assigned(ArchiveFilesProc) then'#013#010+
|
|
|
+ ' FreeAndNil(FZipFile);'#013#010+
|
|
|
+ '{$endif HAS_UNIT_ZIPPER}'#013#010+
|
|
|
+ ' end;'#013#010,
|
|
|
+ ' DoAfterArchive(Apackage);'#013#010+
|
|
|
+ ' Finally'#013#010+
|
|
|
+ ' If (APackage.Directory<>'#039#039') then'#013#010+
|
|
|
+ ' EnterDir('#039#039');'#013#010+
|
|
|
+ ' end;'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ #013#010+
|
|
|
+ 'procedure TBuildEngine.DoBeforeClean(APackage: TPackage);'#013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' ExecuteCommands(APackage.Commands,caBeforeClean);'#013#010+
|
|
|
+ ' ','If Assigned(APackage.BeforeClean) then'#013#010+
|
|
|
+ ' APackage.BeforeClean(APackage);'#013#010+
|
|
|
+ ' If Assigned(APackage.BeforeCleanProc) then'#013#010+
|
|
|
+ ' APackage.BeforeCleanProc(APackage);'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ #013#010+
|
|
|
+ 'procedure TBuildEngine.DoAfterClean(APackage: TPackage);'#013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' ',' If Assigned(APackage.AfterClean) then'#013#010+
|
|
|
+ ' APackage.AfterClean(APackage);'#013#010+
|
|
|
+ ' If Assigned(APackage.AfterInstallProc) then'#013#010+
|
|
|
+ ' APackage.AfterCleanProc(APackage);'#013#010+
|
|
|
+ ' ExecuteCommands(APackage.Commands,caAfterClean);'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ #013#010+
|
|
|
+ 'procedure TBuil','dEngine.Clean(APackage: TPackage; AllTargets: boolean'+
|
|
|
+ ');'#013#010+
|
|
|
+ 'var'#013#010+
|
|
|
+ ' ACPU: TCpu;'#013#010+
|
|
|
+ ' AOS: TOS;'#013#010+
|
|
|
+ ' DirectoryList : TStringList;'#013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' Log(vlInfo,SInfoCleaningPackage,[APackage.Name]);'#013#010+
|
|
|
+ ' try'#013#010+
|
|
|
+ ' If (APackage.Directory<>'#039#039') then'#013#010+
|
|
|
+ ' EnterDi','r(APackage.Directory);'#013#010+
|
|
|
+ ' DoBeforeClean(Apackage);'#013#010+
|
|
|
+ ' if AllTargets then'#013#010+
|
|
|
+ ' begin'#013#010+
|
|
|
+ ' // Remove the unit-and bin-directories completely. This is saf'+
|
|
|
+ 'er in case of files'#013#010+
|
|
|
+ ' // being renamed and such. See also bug 19655'#013#010+
|
|
|
+ ' ',' DirectoryList := TStringList.Create;'#013#010+
|
|
|
+ ' try'#013#010+
|
|
|
+ ' for ACPU:=low(TCpu) to high(TCpu) do'#013#010+
|
|
|
+ ' for AOS:=low(TOS) to high(TOS) do'#013#010+
|
|
|
+ ' begin'#013#010+
|
|
|
+ ' DirectoryList.Add(ExtractFileDir(APackage.GetUnitsOu','t'+
|
|
|
+ 'putDir(ACPU,AOS)));'#013#010+
|
|
|
' DirectoryList.Add(ExtractFileDir(APackage.GetBinOutput'+
|
|
|
- 'Dir(ACPU,AOS)));'#010+
|
|
|
- ' ',' end;'#010+
|
|
|
- ' CmdRemoveTrees(DirectoryList);'#010+
|
|
|
- ' finally'#010+
|
|
|
- ' DirectoryList.Free;'#010+
|
|
|
- ' end;'#010+
|
|
|
- '{ for ACPU:=low(TCpu) to high(TCpu) do'#010+
|
|
|
- ' for AOS:=low(TOS) to high(TOS) do'#010+
|
|
|
- ' begin'#010+
|
|
|
- ' if File','Exists(APackage.GetUnitsOutputDir(ACPU,AOS)) or'+
|
|
|
- #010+
|
|
|
- ' FileExists(APackage.GetBinOutputDir(ACPU,AOS)) then'#010+
|
|
|
- ' Clean(APackage,ACPU,AOS);'#010+
|
|
|
- ' end;}'#010+
|
|
|
- ' end'#010+
|
|
|
- ' else'#010+
|
|
|
- ' Clean(APackage, Defaults.CPU, Defaults','.OS);'#010+
|
|
|
- ' DoAfterClean(Apackage);'#010+
|
|
|
- ' Finally'#010+
|
|
|
- ' If (APackage.Directory<>'#039#039') then'#010+
|
|
|
- ' EnterDir('#039#039');'#010+
|
|
|
- ' end;'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
+ 'Dir(ACPU,AOS)));'#013#010+
|
|
|
+ ' end;'#013#010+
|
|
|
+ ' CmdRemoveTrees(DirectoryList);'#013#010+
|
|
|
+ ' finally'#013#010+
|
|
|
+ ' DirectoryList.Free;'#013#010+
|
|
|
+ ' end;'#013#010+
|
|
|
+ '{ ',' for ACPU:=low(TCpu) to high(TCpu) do'#013#010+
|
|
|
+ ' for AOS:=low(TOS) to high(TOS) do'#013#010+
|
|
|
+ ' begin'#013#010+
|
|
|
+ ' if FileExists(APackage.GetUnitsOutputDir(ACPU,AOS)) or'#013+
|
|
|
+ #010+
|
|
|
+ ' FileExists(APackage.GetBinOutputDir(ACPU,AOS)) t','hen'+
|
|
|
+ #013#010+
|
|
|
+ ' Clean(APackage,ACPU,AOS);'#013#010+
|
|
|
+ ' end;}'#013#010+
|
|
|
+ ' end'#013#010+
|
|
|
+ ' else'#013#010+
|
|
|
+ ' Clean(APackage, Defaults.CPU, Defaults.OS);'#013#010+
|
|
|
+ ' DoAfterClean(Apackage);'#013#010+
|
|
|
+ ' Finally'#013#010+
|
|
|
+ ' If (APackage.Directory<>'#039#039') then'#013#010+
|
|
|
+ ' EnterDir('#039#039');'#013#010+
|
|
|
+ ' ','end;'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
'procedure TBuildEngine.Clean(APackage: TPackage; ACPU: TCPU; AOS: TOS)'+
|
|
|
- ';'#010+
|
|
|
- 'Var'#010+
|
|
|
- ' List : TStringList;'#010+
|
|
|
- ' DirectoryList : TStringLis','t;'#010+
|
|
|
- 'begin'#010+
|
|
|
- ' List:=TStringList.Create;'#010+
|
|
|
- ' try'#010+
|
|
|
- ' List.Add(APackage.GetUnitsOutputDir(ACPU,AOS) + PathDelim + UnitCo'+
|
|
|
- 'nfigFile);'#010+
|
|
|
- ' APackage.GetCleanFiles(List,ACPU,AOS);'#010+
|
|
|
- ' if (List.Count>0) then'#010+
|
|
|
- ' begin'#010+
|
|
|
- ' CmdDeleteFiles(List);'#010+
|
|
|
- ' ','DirectoryList := TStringList.Create;'#010+
|
|
|
- ' try'#010+
|
|
|
- ' GetDirectoriesFromFilelist(List,DirectoryList);'#010+
|
|
|
- ' CmdRemoveDirs(DirectoryList);'#010+
|
|
|
- #010+
|
|
|
- ' DirectoryList.Clear;'#010+
|
|
|
- ' if DirectoryExists(APackage.GetBinOutputDir(ACPU,AOS)) then'#010+
|
|
|
- ' ',' DirectoryList.Add(APackage.GetBinOutputDir(ACPU,AOS));'#010+
|
|
|
- ' if DirectoryExists(APackage.GetUnitsOutputDir(ACPU,AOS)) then'#010+
|
|
|
- ' DirectoryList.Add(APackage.GetUnitsOutputDir(ACPU,AOS));'#010+
|
|
|
- ' CmdRemoveDirs(DirectoryList);'#010+
|
|
|
- #010,
|
|
|
- ' DirectoryList.Clear;'#010+
|
|
|
- ' if DirectoryExists(ExtractFileDir(APackage.GetBinOutputDir(ACP'+
|
|
|
- 'U,AOS))) then'#010+
|
|
|
+ ';'#013#010+
|
|
|
+ 'Var'#013#010+
|
|
|
+ ' List : TStringList;'#013#010+
|
|
|
+ ' DirectoryList : TStringList;'#013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' List:=TStringList.Create;'#013#010+
|
|
|
+ ' try'#013#010+
|
|
|
+ ' List.Add(APackage.GetUnitsOutputDir(ACPU,AOS) ','+ PathDelim + Unit'+
|
|
|
+ 'ConfigFile);'#013#010+
|
|
|
+ ' APackage.GetCleanFiles(List,ACPU,AOS);'#013#010+
|
|
|
+ ' if (List.Count>0) then'#013#010+
|
|
|
+ ' begin'#013#010+
|
|
|
+ ' CmdDeleteFiles(List);'#013#010+
|
|
|
+ ' DirectoryList := TStringList.Create;'#013#010+
|
|
|
+ ' try'#013#010+
|
|
|
+ ' GetDirectoriesFromFilelist(List',',DirectoryList);'#013#010+
|
|
|
+ ' CmdRemoveDirs(DirectoryList);'#013#010+
|
|
|
+ #013#010+
|
|
|
+ ' DirectoryList.Clear;'#013#010+
|
|
|
+ ' if DirectoryExists(APackage.GetBinOutputDir(ACPU,AOS)) then'#013+
|
|
|
+ #010+
|
|
|
+ ' DirectoryList.Add(APackage.GetBinOutputDir(ACPU,AOS));'#013#010+
|
|
|
+ ' if Direc','toryExists(APackage.GetUnitsOutputDir(ACPU,AOS)) the'+
|
|
|
+ 'n'#013#010+
|
|
|
+ ' DirectoryList.Add(APackage.GetUnitsOutputDir(ACPU,AOS));'#013+
|
|
|
+ #010+
|
|
|
+ ' CmdRemoveDirs(DirectoryList);'#013#010+
|
|
|
+ #013#010+
|
|
|
+ ' DirectoryList.Clear;'#013#010+
|
|
|
+ ' if DirectoryExists(ExtractFileDir(APac','kage.GetBinOutputDir(A'+
|
|
|
+ 'CPU,AOS))) then'#013#010+
|
|
|
' DirectoryList.Add(ExtractFileDir(APackage.GetBinOutputDir(AC'+
|
|
|
- 'PU,AOS)));'#010+
|
|
|
- ' if DirectoryExists(ExtractFileDir(APac','kage.GetUnitsOutputDir'+
|
|
|
- '(ACPU,AOS))) then'#010+
|
|
|
- ' DirectoryList.Add(ExtractFileDir(APackage.GetUnitsOutputDir('+
|
|
|
- 'ACPU,AOS)));'#010+
|
|
|
- ' CmdRemoveDirs(DirectoryList);'#010+
|
|
|
- ' finally'#010+
|
|
|
- ' DirectoryList.Free;'#010+
|
|
|
- ' end;'#010+
|
|
|
- ' end;'#010+
|
|
|
- ' Finally'#010+
|
|
|
- ' L','ist.Free;'#010+
|
|
|
- ' end;'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
- #010+
|
|
|
- 'Procedure TBuildEngine.Manifest(APackage : TPackage);'#010+
|
|
|
- 'Var'#010+
|
|
|
- ' L : TStrings;'#010+
|
|
|
- ' PD,'#010+
|
|
|
- ' MF : String;'#010+
|
|
|
- 'begin'#010+
|
|
|
- ' L:=TStringList.Create;'#010+
|
|
|
- ' Try'#010+
|
|
|
- ' Log(vlInfo, Format(SInfoManifestPackage,[APackage.Name]));'#010+
|
|
|
- ' PD:=APackage.Dire','ctory;'#010+
|
|
|
- ' if PD<>'#039#039' then'#010+
|
|
|
- ' PD:=IncludeTrailingPathDelimiter(PD);'#010+
|
|
|
- ' MF:=PD+ManifestFile;'#010+
|
|
|
- ' Log(vlDebug, Format(SDbgGenerating, [MF]));'#010+
|
|
|
- ' L.Add('#039'<?xml version="1.0"?>'#039');'#010+
|
|
|
- ' L.Add('#039'<packages>'#039');'#010+
|
|
|
- ' APackage.GetManifest(L);'#010+
|
|
|
- ' L.A','dd('#039'</packages>'#039');'#010+
|
|
|
- ' L.SaveToFile(MF);'#010+
|
|
|
- ' Finally'#010+
|
|
|
- ' L.Free;'#010+
|
|
|
- ' end;'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
- #010+
|
|
|
- 'procedure TBuildEngine.Compile(Packages: TPackages);'#010+
|
|
|
- #010+
|
|
|
- ' function IsReadyToCompile(APackage:TPackage): boolean;'#010+
|
|
|
- ' begin'#010+
|
|
|
- ' result := False;'#010+
|
|
|
- ' if not APackage.FPr','ocessing and (APackage.State=tsNeutral) then'#010+
|
|
|
- ' begin'#010+
|
|
|
- ' if PackageOK(APackage) then'#010+
|
|
|
- ' result := ReadyToCompile(APackage)'#010+
|
|
|
- ' else'#010+
|
|
|
- ' begin'#010+
|
|
|
- ' inc(FProgressCount);'#010+
|
|
|
- ' log(vlWarning,SWarnSkipPacka','geTargetProgress,[(FProgress'+
|
|
|
- 'Count)/FProgressMax * 100, APackage.Name, Defaults.Target]);'#010+
|
|
|
- ' APackage.FTargetState:=tsNoCompile;'#010+
|
|
|
- ' end;'#010+
|
|
|
- ' end;'#010+
|
|
|
- ' end;'#010+
|
|
|
- #010+
|
|
|
- 'Var'#010+
|
|
|
- ' I : integer;'#010+
|
|
|
- '{$ifndef NO_THREADING}'#010+
|
|
|
- ' Thr : Integer;'#010+
|
|
|
- ' Finished',' : boolean;'#010+
|
|
|
- ' ErrorState: boolean;'#010+
|
|
|
- ' ErrorMessage: string;'#010+
|
|
|
- ' NotifyThreadWaiting : PRTLEvent;'#010+
|
|
|
- ' Threads : array of TCompileWorkerThread;'#010+
|
|
|
- '{$endif NO_THREADING}'#010+
|
|
|
- ' P : TPackage;'#010+
|
|
|
- #010+
|
|
|
- '{$ifndef NO_THREADING}'#010+
|
|
|
- ' procedure ProcessThreadResult(ATHread: ','TCompileWorkerThread);'#010+
|
|
|
- ' var'#010+
|
|
|
- ' StartI: integer;'#010+
|
|
|
- ' CompilePackage: TPackage;'#010+
|
|
|
- ' PackageAvailable: boolean;'#010+
|
|
|
- ' begin'#010+
|
|
|
- ' if AThread.Done then'#010+
|
|
|
- ' begin'#010+
|
|
|
- ' if assigned(AThread.APackage) then'#010+
|
|
|
- ' begin'#010+
|
|
|
- ' // The thread',' has completed compiling the package'#010+
|
|
|
- ' if AThread.CompilationOK then'#010+
|
|
|
- ' AThread.APackage.FTargetState:=tsCompiled'#010+
|
|
|
- ' else // A problem occured, stop the compilation'#010+
|
|
|
- ' begin'#010+
|
|
|
- ' ErrorState:','=true;'#010+
|
|
|
- ' ErrorMessage:=AThread.ErrorMessage;'#010+
|
|
|
- ' Finished:=true;'#010+
|
|
|
- ' end;'#010+
|
|
|
- ' AThread.APackage := nil;'#010+
|
|
|
- ' end;'#010+
|
|
|
- ' StartI := I;'#010+
|
|
|
- #010+
|
|
|
- ' CompilePackage := nil;'#010+
|
|
|
- ' PackageAvailable:=fal','se;'#010+
|
|
|
- ' repeat'#010+
|
|
|
- ' if IsReadyToCompile(Packages.PackageItems[i]) then'#010+
|
|
|
- ' CompilePackage := Packages.PackageItems[i];'#010+
|
|
|
+ 'PU,AOS)));'#013#010+
|
|
|
+ ' if DirectoryExists(ExtractFileDir(APackage.GetUnitsOutputDir(A'+
|
|
|
+ 'CPU,AOS))) then'#013#010+
|
|
|
+ ' DirectoryList.Add(Extr','actFileDir(APackage.GetUnitsOutputDi'+
|
|
|
+ 'r(ACPU,AOS)));'#013#010+
|
|
|
+ ' CmdRemoveDirs(DirectoryList);'#013#010+
|
|
|
+ ' finally'#013#010+
|
|
|
+ ' DirectoryList.Free;'#013#010+
|
|
|
+ ' end;'#013#010+
|
|
|
+ ' end;'#013#010+
|
|
|
+ ' Finally'#013#010+
|
|
|
+ ' List.Free;'#013#010+
|
|
|
+ ' end;'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ #013#010+
|
|
|
+ 'Procedure TBuildEngine.Manifest(APac','kage : TPackage);'#013#010+
|
|
|
+ 'Var'#013#010+
|
|
|
+ ' L : TStrings;'#013#010+
|
|
|
+ ' PD,'#013#010+
|
|
|
+ ' MF : String;'#013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' L:=TStringList.Create;'#013#010+
|
|
|
+ ' Try'#013#010+
|
|
|
+ ' Log(vlInfo, Format(SInfoManifestPackage,[APackage.Name]));'#013#010+
|
|
|
+ ' PD:=APackage.Directory;'#013#010+
|
|
|
+ ' if PD<>'#039#039' then'#013#010+
|
|
|
+ ' PD:=IncludeTraili','ngPathDelimiter(PD);'#013#010+
|
|
|
+ ' MF:=PD+ManifestFile;'#013#010+
|
|
|
+ ' Log(vlDebug, Format(SDbgGenerating, [MF]));'#013#010+
|
|
|
+ ' L.Add('#039'<?xml version="1.0"?>'#039');'#013#010+
|
|
|
+ ' L.Add('#039'<packages>'#039');'#013#010+
|
|
|
+ ' APackage.GetManifest(L);'#013#010+
|
|
|
+ ' L.Add('#039'</packages>'#039');'#013#010+
|
|
|
+ ' L.SaveToFile(MF);'#013#010,
|
|
|
+ ' Finally'#013#010+
|
|
|
+ ' L.Free;'#013#010+
|
|
|
+ ' end;'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ #013#010+
|
|
|
+ 'procedure TBuildEngine.Compile(Packages: TPackages);'#013#010+
|
|
|
+ #013#010+
|
|
|
+ ' function IsReadyToCompile(APackage:TPackage): boolean;'#013#010+
|
|
|
+ ' begin'#013#010+
|
|
|
+ ' result := False;'#013#010+
|
|
|
+ ' if not APackage.FProcessing and (APackage.State=t','sNeutral) then'#013+
|
|
|
+ #010+
|
|
|
+ ' begin'#013#010+
|
|
|
+ ' if PackageOK(APackage) then'#013#010+
|
|
|
+ ' result := ReadyToCompile(APackage)'#013#010+
|
|
|
+ ' else'#013#010+
|
|
|
+ ' begin'#013#010+
|
|
|
+ ' inc(FProgressCount);'#013#010+
|
|
|
+ ' log(vlWarning,SWarnSkipPackageTargetProgress,[(FPro','gress'+
|
|
|
+ 'Count)/FProgressMax * 100, APackage.Name, Defaults.Target]);'#013#010+
|
|
|
+ ' APackage.FTargetState:=tsNoCompile;'#013#010+
|
|
|
+ ' end;'#013#010+
|
|
|
+ ' end;'#013#010+
|
|
|
+ ' end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ 'Var'#013#010+
|
|
|
+ ' I : integer;'#013#010+
|
|
|
+ '{$ifndef NO_THREADING}'#013#010+
|
|
|
+ ' Thr : Integer;'#013#010+
|
|
|
+ ' Finished : boolean;'#013#010,
|
|
|
+ ' ErrorState: boolean;'#013#010+
|
|
|
+ ' ErrorMessage: string;'#013#010+
|
|
|
+ ' NotifyThreadWaiting : PRTLEvent;'#013#010+
|
|
|
+ ' Threads : array of TCompileWorkerThread;'#013#010+
|
|
|
+ '{$endif NO_THREADING}'#013#010+
|
|
|
+ ' P : TPackage;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ '{$ifndef NO_THREADING}'#013#010+
|
|
|
+ ' procedure ProcessThreadResult(ATHread: TCom','pileWorkerThread);'#013#010+
|
|
|
+ ' var'#013#010+
|
|
|
+ ' StartI: integer;'#013#010+
|
|
|
+ ' CompilePackage: TPackage;'#013#010+
|
|
|
+ ' PackageAvailable: boolean;'#013#010+
|
|
|
+ ' begin'#013#010+
|
|
|
+ ' if AThread.Done then'#013#010+
|
|
|
+ ' begin'#013#010+
|
|
|
+ ' if assigned(AThread.APackage) then'#013#010+
|
|
|
+ ' begin'#013#010+
|
|
|
+ ' // The ','thread has completed compiling the package'#013#010+
|
|
|
+ ' if AThread.CompilationOK then'#013#010+
|
|
|
+ ' AThread.APackage.FTargetState:=tsCompiled'#013#010+
|
|
|
+ ' else // A problem occured, stop the compilation'#013#010+
|
|
|
+ ' begin'#013#010+
|
|
|
+ ' ','ErrorState:=true;'#013#010+
|
|
|
+ ' ErrorMessage:=AThread.ErrorMessage;'#013#010+
|
|
|
+ ' Finished:=true;'#013#010+
|
|
|
+ ' end;'#013#010+
|
|
|
+ ' AThread.APackage := nil;'#013#010+
|
|
|
+ ' end;'#013#010+
|
|
|
+ ' StartI := I;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ ' CompilePackage := nil;'#013#010+
|
|
|
+ ' P','ackageAvailable:=false;'#013#010+
|
|
|
+ ' repeat'#013#010+
|
|
|
+ ' if IsReadyToCompile(Packages.PackageItems[i]) then'#013#010+
|
|
|
+ ' CompilePackage := Packages.PackageItems[i];'#013#010+
|
|
|
' if not (Packages.PackageItems[i].State in [tsCompiled, tsNoCom'+
|
|
|
- 'pile]) then'#010+
|
|
|
- ' PackageAvailable',':=true;'#010+
|
|
|
- ' inc(I);'#010+
|
|
|
- ' if I=packages.Count then'#010+
|
|
|
- ' i := 0;'#010+
|
|
|
- ' until Assigned(CompilePackage) or (I=StartI);'#010+
|
|
|
- ' if Assigned(CompilePackage) then'#010+
|
|
|
- ' begin'#010+
|
|
|
- ' // Instruct thread to compile package'#010+
|
|
|
- ' ',' AThread.APackage := CompilePackage;'#010+
|
|
|
- ' AThread.APackage.FProcessing := true;'#010+
|
|
|
- ' AThread.FDone:=False;'#010+
|
|
|
- ' RTLeventSetEvent(AThread.NotifyStartTask);'#010+
|
|
|
- ' end;'#010+
|
|
|
- ' if not PackageAvailable then'#010+
|
|
|
- ' Finis','hed := True;'#010+
|
|
|
- ' end;'#010+
|
|
|
- ' end;'#010+
|
|
|
- #010+
|
|
|
- '{$endif NO_THREADING}'#010+
|
|
|
- #010+
|
|
|
- 'begin'#010+
|
|
|
- ' If Assigned(BeforeCompile) then'#010+
|
|
|
- ' BeforeCompile(Self);'#010+
|
|
|
- ' FProgressMax:=Packages.Count;'#010+
|
|
|
- ' FProgressCount:=0;'#010+
|
|
|
- #010+
|
|
|
- ' if Defaults.ThreadsAmount<0 then'#010+
|
|
|
- ' begin'#010+
|
|
|
- ' // Do not use a','ny threading to compile the packages'#010+
|
|
|
- ' For I:=0 to Packages.Count-1 do'#010+
|
|
|
- ' begin'#010+
|
|
|
- ' P:=Packages.PackageItems[i];'#010+
|
|
|
- ' If PackageOK(P) then'#010+
|
|
|
- ' MaybeCompile(P)'#010+
|
|
|
- ' else'#010+
|
|
|
- ' begin'#010+
|
|
|
- ' inc(FPro','gressCount);'#010+
|
|
|
+ 'pile]) then'#013#010+
|
|
|
+ ' ',' PackageAvailable:=true;'#013#010+
|
|
|
+ ' inc(I);'#013#010+
|
|
|
+ ' if I=packages.Count then'#013#010+
|
|
|
+ ' i := 0;'#013#010+
|
|
|
+ ' until Assigned(CompilePackage) or (I=StartI);'#013#010+
|
|
|
+ ' if Assigned(CompilePackage) then'#013#010+
|
|
|
+ ' begin'#013#010+
|
|
|
+ ' // Instruct ','thread to compile package'#013#010+
|
|
|
+ ' AThread.APackage := CompilePackage;'#013#010+
|
|
|
+ ' AThread.APackage.FProcessing := true;'#013#010+
|
|
|
+ ' AThread.FDone:=False;'#013#010+
|
|
|
+ ' RTLeventSetEvent(AThread.NotifyStartTask);'#013#010+
|
|
|
+ ' end;'#013#010+
|
|
|
+ ' if not',' PackageAvailable then'#013#010+
|
|
|
+ ' Finished := True;'#013#010+
|
|
|
+ ' end;'#013#010+
|
|
|
+ ' end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ '{$endif NO_THREADING}'#013#010+
|
|
|
+ #013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' If Assigned(BeforeCompile) then'#013#010+
|
|
|
+ ' BeforeCompile(Self);'#013#010+
|
|
|
+ ' FProgressMax:=Packages.Count;'#013#010+
|
|
|
+ ' FProgressCount:=0;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ ' if Defaults.T','hreadsAmount<0 then'#013#010+
|
|
|
+ ' begin'#013#010+
|
|
|
+ ' // Do not use any threading to compile the packages'#013#010+
|
|
|
+ ' For I:=0 to Packages.Count-1 do'#013#010+
|
|
|
+ ' begin'#013#010+
|
|
|
+ ' P:=Packages.PackageItems[i];'#013#010+
|
|
|
+ ' If PackageOK(P) then'#013#010+
|
|
|
+ ' MaybeCompil','e(P)'#013#010+
|
|
|
+ ' else'#013#010+
|
|
|
+ ' begin'#013#010+
|
|
|
+ ' inc(FProgressCount);'#013#010+
|
|
|
' log(vlWarning,SWarnSkipPackageTargetProgress,[(FProgressCo'+
|
|
|
- 'unt)/FProgressMax * 100, P.Name, Defaults.Target]);'#010+
|
|
|
- ' end;'#010+
|
|
|
- ' end;'#010+
|
|
|
- ' end'#010+
|
|
|
- ' else'#010+
|
|
|
- ' begin'#010+
|
|
|
- '{$ifndef NO_THREADING}'#010+
|
|
|
- ' // Use worker-threads',' to compile the packages'#010+
|
|
|
- ' ErrorState := False;'#010+
|
|
|
- ' Finished := False;'#010+
|
|
|
- ' I := 0;'#010+
|
|
|
+ 'unt)/FProgressMax * 100, P.Name, Defaults.Target]);'#013#010+
|
|
|
+ ' end;'#013#010+
|
|
|
+ ' end;'#013#010+
|
|
|
+ ' end'#013#010+
|
|
|
+ ' ',' else'#013#010+
|
|
|
+ ' begin'#013#010+
|
|
|
+ '{$ifndef NO_THREADING}'#013#010+
|
|
|
+ ' // Use worker-threads to compile the packages'#013#010+
|
|
|
+ ' ErrorState := False;'#013#010+
|
|
|
+ ' Finished := False;'#013#010+
|
|
|
+ ' I := 0;'#013#010+
|
|
|
' // This event is set by the worker-threads to notify the main/th'+
|
|
|
- 'is thread'#010+
|
|
|
- ' // that a package finished it'#039's task.'#010+
|
|
|
- ' NotifyThreadWaiting',' := RTLEventCreate;'#010+
|
|
|
- ' SetLength(Threads,Defaults.ThreadsAmount);'#010+
|
|
|
- ' // Create all worker-threads'#010+
|
|
|
- ' for Thr:=0 to Defaults.ThreadsAmount-1 do'#010+
|
|
|
- ' Threads[Thr] := TCompileWorkerThread.Create(self,NotifyThreadW'+
|
|
|
- 'aiting);'#010+
|
|
|
- ' try',#010+
|
|
|
+ 'is thr','ead'#013#010+
|
|
|
+ ' // that a package finished it'#039's task.'#013#010+
|
|
|
+ ' NotifyThreadWaiting := RTLEventCreate;'#013#010+
|
|
|
+ ' SetLength(Threads,Defaults.ThreadsAmount);'#013#010+
|
|
|
+ ' // Create all worker-threads'#013#010+
|
|
|
+ ' for Thr:=0 to Defaults.ThreadsAmount-1 do'#013#010+
|
|
|
+ ' T','hreads[Thr] := TCompileWorkerThread.Create(self,NotifyThrea'+
|
|
|
+ 'dWaiting);'#013#010+
|
|
|
+ ' try'#013#010+
|
|
|
' // When a thread notifies this thread that it is ready, loop o'+
|
|
|
- 'n all'#010+
|
|
|
+ 'n all'#013#010+
|
|
|
' // threads to check their state and if possible assign a new p'+
|
|
|
- 'ackage'#010+
|
|
|
- ' // to them to compile.'#010+
|
|
|
- ' while not Finished do'#010+
|
|
|
- ' begin'#010+
|
|
|
- ' ',' RTLeventWaitFor(NotifyThreadWaiting);'#010+
|
|
|
+ 'ackage'#013#010+
|
|
|
+ ' ',' // to them to compile.'#013#010+
|
|
|
+ ' while not Finished do'#013#010+
|
|
|
+ ' begin'#013#010+
|
|
|
+ ' RTLeventWaitFor(NotifyThreadWaiting);'#013#010+
|
|
|
' for Thr:=0 to Defaults.ThreadsAmount-1 do if not Finished '+
|
|
|
- 'then'#010+
|
|
|
- ' ProcessThreadResult(Threads[Thr]);'#010+
|
|
|
- ' end;'#010+
|
|
|
- ' // Compilation finished or aborted. Wait for all thr','eads to '+
|
|
|
- 'end.'#010+
|
|
|
- ' for thr:=0 to Defaults.ThreadsAmount-1 do'#010+
|
|
|
- ' begin'#010+
|
|
|
- ' Threads[Thr].Terminate;'#010+
|
|
|
- ' RTLeventSetEvent(Threads[Thr].NotifyStartTask);'#010+
|
|
|
- ' Threads[Thr].WaitFor;'#010+
|
|
|
- ' end;'#010+
|
|
|
- ' finally'#010+
|
|
|
- ' ',' RTLeventdestroy(NotifyThreadWaiting);'#010+
|
|
|
- ' for thr:=0 to Defaults.ThreadsAmount-1 do'#010+
|
|
|
- ' Threads[Thr].Free;'#010+
|
|
|
- ' end;'#010+
|
|
|
- ' if ErrorState then'#010+
|
|
|
- ' raise Exception.Create(ErrorMessage);'#010+
|
|
|
- '{$endif NO_THREADING}'#010+
|
|
|
- ' end;'#010+
|
|
|
- ' If Ass','igned(AfterCompile) then'#010+
|
|
|
- ' AfterCompile(Self);'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
- #010+
|
|
|
- 'procedure TBuildEngine.Install(Packages: TPackages);'#010+
|
|
|
- 'Var'#010+
|
|
|
- ' I : Integer;'#010+
|
|
|
- ' P : TPackage;'#010+
|
|
|
- 'begin'#010+
|
|
|
- ' If Assigned(BeforeInstall) then'#010+
|
|
|
- ' BeforeInstall(Self);'#010+
|
|
|
- ' For I:=0 to Packages.Count-1 ','do'#010+
|
|
|
- ' begin'#010+
|
|
|
- ' P:=Packages.PackageItems[i];'#010+
|
|
|
- ' If PackageOK(P) then'#010+
|
|
|
- ' begin'#010+
|
|
|
- ' Install(P);'#010+
|
|
|
- ' log(vlWarning, SWarnInstallationPackagecomplete, [P.Name, De'+
|
|
|
- 'faults.Target]);'#010+
|
|
|
- ' end'#010+
|
|
|
- ' else'#010+
|
|
|
- ' log(vlWarni','ng,SWarnSkipPackageTarget,[P.Name, Defaults.Targe'+
|
|
|
- 't]);'#010+
|
|
|
- ' end;'#010+
|
|
|
- ' If Assigned(AfterInstall) then'#010+
|
|
|
- ' AfterInstall(Self);'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
- 'procedure TBuildEngine.ZipInstall(Packages: TPackages);'#010+
|
|
|
- 'var'#010+
|
|
|
- ' I : Integer;'#010+
|
|
|
- ' P : TPackage;'#010+
|
|
|
- 'begin'#010+
|
|
|
- ' If Assigned(Bef','oreInstall) then'#010+
|
|
|
- ' BeforeInstall(Self);'#010+
|
|
|
- #010+
|
|
|
- ' FZipper := TZipper.Create;'#010+
|
|
|
- ' try'#010+
|
|
|
- ' Defaults.IntSetBaseInstallDir('#039'lib/fpc/'#039' + Defaults.FCompi'+
|
|
|
- 'lerVersion+ '#039'/'#039');'#010+
|
|
|
- ' For I:=0 to Packages.Count-1 do'#010+
|
|
|
- ' begin'#010+
|
|
|
- ' P:=Packages.PackageItems[i','];'#010+
|
|
|
- ' If PackageOK(P) then'#010+
|
|
|
- ' begin'#010+
|
|
|
- ' FZipper.FileName := P.Name + '#039'.'#039' + MakeTargetStrin'+
|
|
|
- 'g(Defaults.CPU,Defaults.OS) +'#039'.zip'#039';'#010+
|
|
|
- ' Install(P);'#010+
|
|
|
- ' FZipper.ZipAllFiles;'#010+
|
|
|
- ' FZipper.Clear;'#010+
|
|
|
- ' ',' log(vlWarning, SWarnInstallationPackagecomplete, [P.Name'+
|
|
|
- ', Defaults.Target]);'#010+
|
|
|
- ' end'#010+
|
|
|
- ' else'#010+
|
|
|
+ 'then'#013#010+
|
|
|
+ ' ProcessThreadResult(Th','reads[Thr]);'#013#010+
|
|
|
+ ' end;'#013#010+
|
|
|
+ ' // Compilation finished or aborted. Wait for all threads to en'+
|
|
|
+ 'd.'#013#010+
|
|
|
+ ' for thr:=0 to Defaults.ThreadsAmount-1 do'#013#010+
|
|
|
+ ' begin'#013#010+
|
|
|
+ ' Threads[Thr].Terminate;'#013#010+
|
|
|
+ ' RTLeventSetEvent(Th','reads[Thr].NotifyStartTask);'#013#010+
|
|
|
+ ' Threads[Thr].WaitFor;'#013#010+
|
|
|
+ ' end;'#013#010+
|
|
|
+ ' finally'#013#010+
|
|
|
+ ' RTLeventdestroy(NotifyThreadWaiting);'#013#010+
|
|
|
+ ' for thr:=0 to Defaults.ThreadsAmount-1 do'#013#010+
|
|
|
+ ' Threads[Thr].Free;'#013#010+
|
|
|
+ ' end;'#013#010+
|
|
|
+ ' ','if ErrorState then'#013#010+
|
|
|
+ ' raise Exception.Create(ErrorMessage);'#013#010+
|
|
|
+ '{$endif NO_THREADING}'#013#010+
|
|
|
+ ' end;'#013#010+
|
|
|
+ ' If Assigned(AfterCompile) then'#013#010+
|
|
|
+ ' AfterCompile(Self);'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ #013#010+
|
|
|
+ 'procedure TBuildEngine.Install(Packages: TPackages);'#013#010+
|
|
|
+ 'Var'#013#010+
|
|
|
+ ' I : Integer;',#013#010+
|
|
|
+ ' P : TPackage;'#013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' If Assigned(BeforeInstall) then'#013#010+
|
|
|
+ ' BeforeInstall(Self);'#013#010+
|
|
|
+ ' For I:=0 to Packages.Count-1 do'#013#010+
|
|
|
+ ' begin'#013#010+
|
|
|
+ ' P:=Packages.PackageItems[i];'#013#010+
|
|
|
+ ' If PackageOK(P) then'#013#010+
|
|
|
+ ' begin'#013#010+
|
|
|
+ ' Install(P);'#013#010+
|
|
|
+ ' ',' log(vlWarning, SWarnInstallationPackagecomplete, [P.Name, '+
|
|
|
+ 'Defaults.Target]);'#013#010+
|
|
|
+ ' end'#013#010+
|
|
|
+ ' else'#013#010+
|
|
|
+ ' log(vlWarning,SWarnSkipPackageTarget,[P.Name, Defaults.Target]'+
|
|
|
+ ');'#013#010+
|
|
|
+ ' end;'#013#010+
|
|
|
+ ' If Assigned(AfterInstall) then'#013#010+
|
|
|
+ ' AfterInsta','ll(Self);'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ 'procedure TBuildEngine.ZipInstall(Packages: TPackages);'#013#010+
|
|
|
+ 'var'#013#010+
|
|
|
+ ' I : Integer;'#013#010+
|
|
|
+ ' P : TPackage;'#013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' If Assigned(BeforeInstall) then'#013#010+
|
|
|
+ ' BeforeInstall(Self);'#013#010+
|
|
|
+ #013#010+
|
|
|
+ ' FZipper := TZipper.Create;'#013#010+
|
|
|
+ ' try'#013#010+
|
|
|
+ ' Defaults.IntSet','BaseInstallDir('#039'lib/fpc/'#039' + Defaults.FCom'+
|
|
|
+ 'pilerVersion+ '#039'/'#039');'#013#010+
|
|
|
+ ' For I:=0 to Packages.Count-1 do'#013#010+
|
|
|
+ ' begin'#013#010+
|
|
|
+ ' P:=Packages.PackageItems[i];'#013#010+
|
|
|
+ ' If PackageOK(P) then'#013#010+
|
|
|
+ ' begin'#013#010+
|
|
|
+ ' FZipper.FileName := P.Name + '#039'.',#039' + MakeTargetStrin'+
|
|
|
+ 'g(Defaults.CPU,Defaults.OS) +'#039'.zip'#039';'#013#010+
|
|
|
+ ' Install(P);'#013#010+
|
|
|
+ ' FZipper.ZipAllFiles;'#013#010+
|
|
|
+ ' FZipper.Clear;'#013#010+
|
|
|
+ ' log(vlWarning, SWarnInstallationPackagecomplete, [P.Name, '+
|
|
|
+ 'Defaults.Target]);'#013#010+
|
|
|
+ ' ',' end'#013#010+
|
|
|
+ ' else'#013#010+
|
|
|
' log(vlWarning,SWarnSkipPackageTarget,[P.Name, Defaults.Targe'+
|
|
|
- 't]);'#010+
|
|
|
- ' end;'#010+
|
|
|
- ' finally'#010+
|
|
|
- ' FZipper.Free;'#010+
|
|
|
- ' end;'#010+
|
|
|
- #010+
|
|
|
- ' If Assign','ed(AfterInstall) then'#010+
|
|
|
- ' AfterInstall(Self);'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
- #010+
|
|
|
- 'procedure TBuildEngine.Archive(Packages: TPackages);'#010+
|
|
|
- 'Var'#010+
|
|
|
- ' I : Integer;'#010+
|
|
|
- ' P : TPackage;'#010+
|
|
|
- 'begin'#010+
|
|
|
- ' If Assigned(BeforeArchive) then'#010+
|
|
|
- ' BeforeArchive(Self);'#010+
|
|
|
- ' Log(vlDebug, SDbgBuildEngineArch','iving);'#010+
|
|
|
- ' For I:=0 to Packages.Count-1 do'#010+
|
|
|
- ' begin'#010+
|
|
|
- ' P:=Packages.PackageItems[i];'#010+
|
|
|
- ' Archive(P);'#010+
|
|
|
- ' end;'#010+
|
|
|
- ' If Assigned(AfterArchive) then'#010+
|
|
|
- ' AfterArchive(Self);'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
- #010+
|
|
|
- 'procedure TBuildEngine.Manifest(Packages: TPackages);'#010+
|
|
|
- 'Var'#010+
|
|
|
- ' I ',': Integer;'#010+
|
|
|
- ' P : TPackage;'#010+
|
|
|
- 'begin'#010+
|
|
|
- ' If Assigned(BeforeManifest) then'#010+
|
|
|
- ' BeforeManifest(Self);'#010+
|
|
|
- ' Log(vlDebug, SDbgBuildEngineGenerateManifests);'#010+
|
|
|
- ' For I:=0 to Packages.Count-1 do'#010+
|
|
|
- ' begin'#010+
|
|
|
- ' P:=Packages.PackageItems[i];'#010+
|
|
|
- ' Manifest(P)',';'#010+
|
|
|
- ' end;'#010+
|
|
|
- ' If Assigned(AfterManifest) then'#010+
|
|
|
- ' AfterManifest(Self);'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
- #010+
|
|
|
+ 't]);'#013#010+
|
|
|
+ ' end;'#013#010+
|
|
|
+ ' finally'#013#010+
|
|
|
+ ' FZipper.Free;'#013#010+
|
|
|
+ ' end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ ' If Assigned(AfterInstall) then'#013#010+
|
|
|
+ ' AfterInstall(Self);'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ #013#010+
|
|
|
+ 'procedure TBuildEngi','ne.Archive(Packages: TPackages);'#013#010+
|
|
|
+ 'Var'#013#010+
|
|
|
+ ' I : Integer;'#013#010+
|
|
|
+ ' P : TPackage;'#013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' If Assigned(BeforeArchive) then'#013#010+
|
|
|
+ ' BeforeArchive(Self);'#013#010+
|
|
|
+ ' Log(vlDebug, SDbgBuildEngineArchiving);'#013#010+
|
|
|
+ ' For I:=0 to Packages.Count-1 do'#013#010+
|
|
|
+ ' begin'#013#010+
|
|
|
+ ' P:=Pa','ckages.PackageItems[i];'#013#010+
|
|
|
+ ' Archive(P);'#013#010+
|
|
|
+ ' end;'#013#010+
|
|
|
+ ' If Assigned(AfterArchive) then'#013#010+
|
|
|
+ ' AfterArchive(Self);'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ #013#010+
|
|
|
+ 'procedure TBuildEngine.Manifest(Packages: TPackages);'#013#010+
|
|
|
+ 'Var'#013#010+
|
|
|
+ ' I : Integer;'#013#010+
|
|
|
+ ' P : TPackage;'#013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' If Assigned(Bef','oreManifest) then'#013#010+
|
|
|
+ ' BeforeManifest(Self);'#013#010+
|
|
|
+ ' Log(vlDebug, SDbgBuildEngineGenerateManifests);'#013#010+
|
|
|
+ ' For I:=0 to Packages.Count-1 do'#013#010+
|
|
|
+ ' begin'#013#010+
|
|
|
+ ' P:=Packages.PackageItems[i];'#013#010+
|
|
|
+ ' Manifest(P);'#013#010+
|
|
|
+ ' end;'#013#010+
|
|
|
+ ' If Assigned(AfterManifest) th','en'#013#010+
|
|
|
+ ' AfterManifest(Self);'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ #013#010+
|
|
|
'procedure TBuildEngine.Clean(Packages: TPackages; AllTargets: boolean)'+
|
|
|
- ';'#010+
|
|
|
- 'Var'#010+
|
|
|
- ' I : Integer;'#010+
|
|
|
- ' P : TPackage;'#010+
|
|
|
- 'begin'#010+
|
|
|
- ' If Assigned(BeforeClean) then'#010+
|
|
|
- ' BeforeClean(Se','lf);'#010+
|
|
|
- ' Log(vldebug, SDbgBuildEngineCleaning);'#010+
|
|
|
- ' For I:=0 to Packages.Count-1 do'#010+
|
|
|
- ' begin'#010+
|
|
|
- ' P:=Packages.PackageItems[i];'#010+
|
|
|
- ' If AllTargets or PackageOK(P) then'#010+
|
|
|
- ' Clean(P, AllTargets);'#010+
|
|
|
- ' log(vlWarning, SWarnCleanPackagecomplete, [P.N','ame]);'#010+
|
|
|
- ' end;'#010+
|
|
|
- ' If Assigned(AfterClean) then'#010+
|
|
|
- ' AfterClean(Self);'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
+ ';'#013#010+
|
|
|
+ 'Var'#013#010+
|
|
|
+ ' I : Integer;'#013#010+
|
|
|
+ ' P : TPackage;'#013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' If Assigned(BeforeClean) then'#013#010+
|
|
|
+ ' BeforeClean(Self);'#013#010+
|
|
|
+ ' Log(vldebug, SDbgBuildE','ngineCleaning);'#013#010+
|
|
|
+ ' For I:=0 to Packages.Count-1 do'#013#010+
|
|
|
+ ' begin'#013#010+
|
|
|
+ ' P:=Packages.PackageItems[i];'#013#010+
|
|
|
+ ' If AllTargets or PackageOK(P) then'#013#010+
|
|
|
+ ' Clean(P, AllTargets);'#013#010+
|
|
|
+ ' log(vlWarning, SWarnCleanPackagecomplete, [P.Name]);'#013#010+
|
|
|
+ ' end;'#013#010+
|
|
|
+ ' If A','ssigned(AfterClean) then'#013#010+
|
|
|
+ ' AfterClean(Self);'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
'{*********************************************************************'+
|
|
|
- '*******'#010+
|
|
|
- ' TFPVersion'#010+
|
|
|
- '*********************************************','***********************'+
|
|
|
- '********}'#010+
|
|
|
- #010+
|
|
|
- 'function TFPVersion.GetAsString: String;'#010+
|
|
|
- 'begin'#010+
|
|
|
- ' if Empty then'#010+
|
|
|
- ' Result:='#039'<none>'#039#010+
|
|
|
- ' else'#010+
|
|
|
- ' begin'#010+
|
|
|
- ' Result := '#039#039';'#010+
|
|
|
- ' if Major <> -1 then'#010+
|
|
|
- ' Result := Result + IntToStr(Major);'#010+
|
|
|
- ' if Minor <> -1 then',#010+
|
|
|
- ' Result := Result + '#039'.'#039' + IntToStr(Minor);'#010+
|
|
|
- ' if Micro <> -1 then'#010+
|
|
|
- ' Result := Result + '#039'.'#039' + IntToStr(Micro);'#010+
|
|
|
- ' if Build <> -1 then'#010+
|
|
|
- ' Result := Result + '#039'-'#039' + IntToStr(Build);'#010+
|
|
|
- ' end;'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
- 'function TFPVersion.GetEmpty: Boo','lean;'#010+
|
|
|
- 'begin'#010+
|
|
|
- ' Result:=(Major=0) and (Minor=0) and (Micro=0) and (Build=0);'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
- 'procedure TFPVersion.SetAsString(const AValue: String);'#010+
|
|
|
- #010+
|
|
|
- ' Function NextDigit(sep : Char; var V : string) : integer;'#010+
|
|
|
- ' Var'#010+
|
|
|
- ' P : Integer;'#010+
|
|
|
- ' begin'#010+
|
|
|
- ' P:=Pos(','Sep,V);'#010+
|
|
|
- ' If (P=0) then'#010+
|
|
|
- ' P:=Length(V)+1;'#010+
|
|
|
- ' Result:=StrToIntDef(Copy(V,1,P-1),-1);'#010+
|
|
|
- ' If Result<>-1 then'#010+
|
|
|
- ' Delete(V,1,P);'#010+
|
|
|
- ' end;'#010+
|
|
|
- #010+
|
|
|
- 'Var'#010+
|
|
|
- ' V : String;'#010+
|
|
|
- 'begin'#010+
|
|
|
- ' Clear;'#010+
|
|
|
- ' // Special support for empty version string'#010+
|
|
|
- ' if (AValue='#039#039') o','r (AValue='#039'<none>'#039') then'#010+
|
|
|
- ' exit;'#010+
|
|
|
- ' V:=AValue;'#010+
|
|
|
- ' Major:=NextDigit('#039'.'#039',V);'#010+
|
|
|
- ' Minor:=NextDigit('#039'.'#039',V);'#010+
|
|
|
- ' Micro:=NextDigit('#039'-'#039',V);'#010+
|
|
|
- ' Build:=NextDigit(#0,V);'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
- 'procedure TFPVersion.Clear;'#010+
|
|
|
- 'begin'#010+
|
|
|
- ' Micro:=-1;'#010+
|
|
|
- ' Major:=-1;'#010+
|
|
|
- ' Minor:=-1;'#010+
|
|
|
- ' Buil','d:=-1;'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
- 'procedure TFPVersion.Assign(Source: TPersistent);'#010+
|
|
|
- 'Var'#010+
|
|
|
- ' V : TFPVersion;'#010+
|
|
|
- 'begin'#010+
|
|
|
- ' if Source is TFPVersion then'#010+
|
|
|
- ' begin'#010+
|
|
|
- ' V:=Source as TFPVersion;'#010+
|
|
|
- ' Major:=V.Major;'#010+
|
|
|
- ' Minor:=V.Minor;'#010+
|
|
|
- ' Micro:=V.Micro;'#010+
|
|
|
- ' Build:=V.Build;',#010+
|
|
|
- ' end'#010+
|
|
|
- ' else'#010+
|
|
|
- ' inherited Assign(Source);'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
- 'function TFPVersion.CompareVersion(AVersion: TFPVersion): Integer;'#010+
|
|
|
- 'begin'#010+
|
|
|
- ' Result:=Major-AVersion.Major;'#010+
|
|
|
- ' If (Result=0) then'#010+
|
|
|
- ' begin'#010+
|
|
|
- ' Result:=Minor-AVersion.Minor;'#010+
|
|
|
- ' if (Result','=0) then'#010+
|
|
|
- ' begin'#010+
|
|
|
- ' Result:=Micro-AVersion.Micro;'#010+
|
|
|
- ' If (Result=0) then'#010+
|
|
|
- ' Result:=Build-AVersion.Build;'#010+
|
|
|
- ' end;'#010+
|
|
|
- ' end;'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
- 'function TFPVersion.SameVersion(AVersion: TFPVersion): Boolean;'#010+
|
|
|
- 'begin'#010+
|
|
|
- ' Result',':=CompareVersion(AVersion)=0;'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
- #010+
|
|
|
+ '*******'#013#010+
|
|
|
+ ' TFPVersion'#013#010+
|
|
|
+ '*************************************************************','*******'+
|
|
|
+ '********}'#013#010+
|
|
|
+ #013#010+
|
|
|
+ 'function TFPVersion.GetAsString: String;'#013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' if Empty then'#013#010+
|
|
|
+ ' Result:='#039'<none>'#039#013#010+
|
|
|
+ ' else'#013#010+
|
|
|
+ ' begin'#013#010+
|
|
|
+ ' Result := '#039#039';'#013#010+
|
|
|
+ ' if Major <> -1 then'#013#010+
|
|
|
+ ' Result := Result + IntToStr(Major);'#013#010+
|
|
|
+ ' if Minor <> -1 then'#013#010+
|
|
|
+ ' ',' Result := Result + '#039'.'#039' + IntToStr(Minor);'#013#010+
|
|
|
+ ' if Micro <> -1 then'#013#010+
|
|
|
+ ' Result := Result + '#039'.'#039' + IntToStr(Micro);'#013#010+
|
|
|
+ ' if Build <> -1 then'#013#010+
|
|
|
+ ' Result := Result + '#039'-'#039' + IntToStr(Build);'#013#010+
|
|
|
+ ' end;'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ 'function TFPVersion.GetEmpty:',' Boolean;'#013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' Result:=(Major=0) and (Minor=0) and (Micro=0) and (Build=0);'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ 'procedure TFPVersion.SetAsString(const AValue: String);'#013#010+
|
|
|
+ #013#010+
|
|
|
+ ' Function NextDigit(sep : Char; var V : string) : integer;'#013#010+
|
|
|
+ ' Var'#013#010+
|
|
|
+ ' P : Integer;'#013#010+
|
|
|
+ ' beg','in'#013#010+
|
|
|
+ ' P:=Pos(Sep,V);'#013#010+
|
|
|
+ ' If (P=0) then'#013#010+
|
|
|
+ ' P:=Length(V)+1;'#013#010+
|
|
|
+ ' Result:=StrToIntDef(Copy(V,1,P-1),-1);'#013#010+
|
|
|
+ ' If Result<>-1 then'#013#010+
|
|
|
+ ' Delete(V,1,P);'#013#010+
|
|
|
+ ' end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ 'Var'#013#010+
|
|
|
+ ' V : String;'#013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' Clear;'#013#010+
|
|
|
+ ' // Special support for empty versio','n string'#013#010+
|
|
|
+ ' if (AValue='#039#039') or (AValue='#039'<none>'#039') then'#013#010+
|
|
|
+ ' exit;'#013#010+
|
|
|
+ ' V:=AValue;'#013#010+
|
|
|
+ ' Major:=NextDigit('#039'.'#039',V);'#013#010+
|
|
|
+ ' Minor:=NextDigit('#039'.'#039',V);'#013#010+
|
|
|
+ ' Micro:=NextDigit('#039'-'#039',V);'#013#010+
|
|
|
+ ' Build:=NextDigit(#0,V);'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ 'procedure TFPVersion.Clear;'#013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' Micr','o:=-1;'#013#010+
|
|
|
+ ' Major:=-1;'#013#010+
|
|
|
+ ' Minor:=-1;'#013#010+
|
|
|
+ ' Build:=-1;'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ 'procedure TFPVersion.Assign(Source: TPersistent);'#013#010+
|
|
|
+ 'Var'#013#010+
|
|
|
+ ' V : TFPVersion;'#013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' if Source is TFPVersion then'#013#010+
|
|
|
+ ' begin'#013#010+
|
|
|
+ ' V:=Source as TFPVersion;'#013#010+
|
|
|
+ ' Major:=V.Major;'#013#010+
|
|
|
+ ' Mi','nor:=V.Minor;'#013#010+
|
|
|
+ ' Micro:=V.Micro;'#013#010+
|
|
|
+ ' Build:=V.Build;'#013#010+
|
|
|
+ ' end'#013#010+
|
|
|
+ ' else'#013#010+
|
|
|
+ ' inherited Assign(Source);'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ 'function TFPVersion.CompareVersion(AVersion: TFPVersion): Integer;'#013+
|
|
|
+ #010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' Result:=Major-AVersion.Major;'#013#010+
|
|
|
+ ' If (Result=0) the','n'#013#010+
|
|
|
+ ' begin'#013#010+
|
|
|
+ ' Result:=Minor-AVersion.Minor;'#013#010+
|
|
|
+ ' if (Result=0) then'#013#010+
|
|
|
+ ' begin'#013#010+
|
|
|
+ ' Result:=Micro-AVersion.Micro;'#013#010+
|
|
|
+ ' If (Result=0) then'#013#010+
|
|
|
+ ' Result:=Build-AVersion.Build;'#013#010+
|
|
|
+ ' end;'#013#010+
|
|
|
+ ' end;'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ 'fu','nction TFPVersion.SameVersion(AVersion: TFPVersion): Boolean;'#013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' Result:=CompareVersion(AVersion)=0;'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ #013#010+
|
|
|
'{*********************************************************************'+
|
|
|
- '*******'#010+
|
|
|
- ' TTarget'#010+
|
|
|
+ '*******'#013#010+
|
|
|
+ ' TTarget'#013#010,
|
|
|
'**********************************************************************'+
|
|
|
- '******}'#010+
|
|
|
- #010+
|
|
|
- 'const','ructor TTarget.Create(ACollection: TCollection);'#010+
|
|
|
- 'begin'#010+
|
|
|
- ' inherited Create(ACollection);'#010+
|
|
|
- ' FInstall:=True;'#010+
|
|
|
- ' FCPUs:=AllCPUs;'#010+
|
|
|
- ' FOSes:=AllOSes;'#010+
|
|
|
- ' FUnitPath:=TConditionalStrings.Create(TConditionalString);'#010+
|
|
|
- ' FIncludePath:=TConditionalStrings.C','reate(TConditionalString);'#010+
|
|
|
- ' FObjectPath:=TConditionalStrings.Create(TConditionalString);'#010+
|
|
|
- ' FDependencies:=TDependencies.Create(TDependency);'#010+
|
|
|
- ' FCommands:=TCommands.Create(TCommand);'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
- #010+
|
|
|
- 'destructor TTarget.Destroy;'#010+
|
|
|
- 'begin'#010+
|
|
|
- ' FreeAndNil(FUn','itPath);'#010+
|
|
|
- ' FreeAndNil(FObjectPath);'#010+
|
|
|
- ' FreeAndNil(FIncludePath);'#010+
|
|
|
- ' FreeAndNil(FDependencies);'#010+
|
|
|
- ' FreeAndNil(FCommands);'#010+
|
|
|
- ' FreeAndNil(Foptions);'#010+
|
|
|
- ' inherited Destroy;'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
- 'procedure TTarget.AssignTo(Dest: TPersistent);'#010+
|
|
|
- 'var'#010+
|
|
|
- ' DestTarget: TTarge','t;'#010+
|
|
|
- 'begin'#010+
|
|
|
- ' if Dest is TTarget then'#010+
|
|
|
- ' begin'#010+
|
|
|
- ' DestTarget := TTarget(Dest);'#010+
|
|
|
- ' DestTarget.Dependencies.Assign(Dependencies);'#010+
|
|
|
- ' DestTarget.Commands.Assign(Commands);'#010+
|
|
|
- ' DestTarget.FTargetState := FTargetState;'#010+
|
|
|
- ' DestTarget.TargetType',' := TargetType;'#010+
|
|
|
- ' DestTarget.CPUs := CPUs;'#010+
|
|
|
- ' DestTarget.OSes := OSes;'#010+
|
|
|
- ' DestTarget.Mode := Mode;'#010+
|
|
|
- ' DestTarget.Options := Options;'#010+
|
|
|
- ' DestTarget.Name := Name;'#010+
|
|
|
- ' DestTarget.Extension:= Extension;'#010+
|
|
|
- ' DestTarget.FPCTarget := FPCTar','get;'#010+
|
|
|
- ' DestTarget.FileType := FileType;'#010+
|
|
|
- ' DestTarget.Directory := Directory;'#010+
|
|
|
- ' DestTarget.ResourceStrings := ResourceStrings;'#010+
|
|
|
- ' DestTarget.Install := Install;'#010+
|
|
|
- ' DestTarget.FTargetSourceFileName := fTargetSourceFileName;'#010+
|
|
|
- ' DestTa','rget.ObjectPath.Assign(ObjectPath);'#010+
|
|
|
- ' DestTarget.UnitPath.Assign(UnitPath);'#010+
|
|
|
- ' DestTarget.IncludePath.Assign(IncludePath);'#010+
|
|
|
- ' DestTarget.FXML := FXML;'#010+
|
|
|
- ' DestTarget.AfterCompile := AfterCompile;'#010+
|
|
|
- ' DestTarget.BeforeCompile := BeforeCo','mpile;'#010+
|
|
|
- ' DestTarget.BeforeClean := BeforeCompile;'#010+
|
|
|
- ' DestTarget.AfterClean := AfterClean;'#010+
|
|
|
- ' end'#010+
|
|
|
- ' else'#010+
|
|
|
- ' inherited AssignTo(Dest);'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
- 'function TTarget.GetOptions: TStrings;'#010+
|
|
|
- 'begin'#010+
|
|
|
- ' If Foptions=Nil then'#010+
|
|
|
- ' FOptions:=TStringList.Cr','eate;'#010+
|
|
|
- ' Result:=FOptions;'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
- 'function TTarget.GetImportLibFileName(AOS : TOS) : String;'#010+
|
|
|
- 'begin'#010+
|
|
|
- ' result := GetImportLibraryFilename(Name,AOS);'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
- 'function TTarget.GetUnitLibFileName: String;'#010+
|
|
|
- 'begin'#010+
|
|
|
- ' Result:='#039'libp'#039'+Name+LibExt;'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
- 'pr','ocedure TTarget.SetOptions(const AValue: TStrings);'#010+
|
|
|
- 'begin'#010+
|
|
|
- ' If (AValue=Nil) or (AValue.Count=0) then'#010+
|
|
|
- ' FreeAndNil(FOptions)'#010+
|
|
|
- ' else'#010+
|
|
|
- ' Options.Assign(AValue);'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
- 'function TTarget.GetSourceFileName: String;'#010+
|
|
|
- 'begin'#010+
|
|
|
- ' Result:=Name+FExtensi','on;'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
- #010+
|
|
|
- 'function TTarget.GetUnitFileName: String;'#010+
|
|
|
- 'begin'#010+
|
|
|
- ' Result:=Name+UnitExt;'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
- #010+
|
|
|
- 'function TTarget.GetObjectFileName: String;'#010+
|
|
|
- 'begin'#010+
|
|
|
- ' Result:=Name+ObjExt;'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
- #010+
|
|
|
- 'function TTarget.GetRSTFileName: String;'#010+
|
|
|
- 'begin'#010+
|
|
|
- ' Result:=Name+RSText;'#010,
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
- #010+
|
|
|
- 'function TTarget.GetProgramFileName(AOS : TOS): String;'#010+
|
|
|
- 'begin'#010+
|
|
|
- ' result := AddProgramExtension(Name, AOS);'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
- #010+
|
|
|
- 'function TTarget.GetProgramDebugFileName(AOS: TOS): String;'#010+
|
|
|
- 'begin'#010+
|
|
|
- ' result := Name + DbgExt;'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
- #010+
|
|
|
- 'function TTarget.Get','OutputFileName(AOs: TOS): String;'#010+
|
|
|
- 'begin'#010+
|
|
|
- ' if TargetType in UnitTargets then'#010+
|
|
|
- ' Result:=GetUnitFileName'#010+
|
|
|
- ' else'#010+
|
|
|
- ' Result:=GetProgramFileName(AOs);'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
- 'function TTarget.HaveOptions: Boolean;'#010+
|
|
|
- 'begin'#010+
|
|
|
- ' Result:=(FOptions<>Nil);'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
- #010+
|
|
|
- 'procedu','re TTarget.SetName(const AValue: String);'#010+
|
|
|
- 'Var'#010+
|
|
|
- ' D,N,E : String;'#010+
|
|
|
- 'begin'#010+
|
|
|
- ' N:=FixPath(AValue, False);'#010+
|
|
|
- ' D:=ExtractFilePath(N);'#010+
|
|
|
- ' E:=ExtractFileExt(N);'#010+
|
|
|
- ' N:=ExtractFileName(N);'#010+
|
|
|
- ' inherited SetName(Copy(N,1,Length(N)-Length(E)));'#010+
|
|
|
- ' FExtension:=E',';'#010+
|
|
|
- ' FDirectory:=D;'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
- 'procedure TTarget.SetXML(const AValue: string);'#010+
|
|
|
- 'begin'#010+
|
|
|
- ' FXML:=FixPath(AValue, False);'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
+ '******}'#013#010+
|
|
|
+ #013#010+
|
|
|
+ 'constructor TTarget.Create(ACollection: TCollection);'#013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' inherited Create(ACollection);'#013#010+
|
|
|
+ ' FInstall:=True;'#013#010+
|
|
|
+ ' FCPUs:=AllCPUs;'#013#010+
|
|
|
+ ' FOSes:=AllOSes;'#013#010+
|
|
|
+ ' FUni','tPath:=TConditionalStrings.Create(TConditionalString);'#013#010+
|
|
|
+ ' FIncludePath:=TConditionalStrings.Create(TConditionalString);'#013#010+
|
|
|
+ ' FObjectPath:=TConditionalStrings.Create(TConditionalString);'#013#010+
|
|
|
+ ' FDependencies:=TDependencies.Create(TDependency);'#013#010+
|
|
|
+ ' ','FCommands:=TCommands.Create(TCommand);'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ #013#010+
|
|
|
+ 'destructor TTarget.Destroy;'#013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' FreeAndNil(FUnitPath);'#013#010+
|
|
|
+ ' FreeAndNil(FObjectPath);'#013#010+
|
|
|
+ ' FreeAndNil(FIncludePath);'#013#010+
|
|
|
+ ' FreeAndNil(FDependencies);'#013#010+
|
|
|
+ ' FreeAndNil(FCommands);'#013#010+
|
|
|
+ ' FreeAndNil(Fo','ptions);'#013#010+
|
|
|
+ ' inherited Destroy;'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ 'procedure TTarget.AssignTo(Dest: TPersistent);'#013#010+
|
|
|
+ 'var'#013#010+
|
|
|
+ ' DestTarget: TTarget;'#013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' if Dest is TTarget then'#013#010+
|
|
|
+ ' begin'#013#010+
|
|
|
+ ' DestTarget := TTarget(Dest);'#013#010+
|
|
|
+ ' DestTarget.Dependencies.Assign(Dependenc','ies);'#013#010+
|
|
|
+ ' DestTarget.Commands.Assign(Commands);'#013#010+
|
|
|
+ ' DestTarget.FTargetState := FTargetState;'#013#010+
|
|
|
+ ' DestTarget.TargetType := TargetType;'#013#010+
|
|
|
+ ' DestTarget.CPUs := CPUs;'#013#010+
|
|
|
+ ' DestTarget.OSes := OSes;'#013#010+
|
|
|
+ ' DestTarget.Mode := Mode;'#013#010+
|
|
|
+ ' DestTarg','et.Options := Options;'#013#010+
|
|
|
+ ' DestTarget.Name := Name;'#013#010+
|
|
|
+ ' DestTarget.Extension:= Extension;'#013#010+
|
|
|
+ ' DestTarget.FPCTarget := FPCTarget;'#013#010+
|
|
|
+ ' DestTarget.FileType := FileType;'#013#010+
|
|
|
+ ' DestTarget.Directory := Directory;'#013#010+
|
|
|
+ ' DestTarget.ResourceStrin','gs := ResourceStrings;'#013#010+
|
|
|
+ ' DestTarget.Install := Install;'#013#010+
|
|
|
+ ' DestTarget.FTargetSourceFileName := fTargetSourceFileName;'#013#010+
|
|
|
+ ' DestTarget.ObjectPath.Assign(ObjectPath);'#013#010+
|
|
|
+ ' DestTarget.UnitPath.Assign(UnitPath);'#013#010+
|
|
|
+ ' DestTarget.IncludePath','.Assign(IncludePath);'#013#010+
|
|
|
+ ' DestTarget.FXML := FXML;'#013#010+
|
|
|
+ ' DestTarget.AfterCompile := AfterCompile;'#013#010+
|
|
|
+ ' DestTarget.BeforeCompile := BeforeCompile;'#013#010+
|
|
|
+ ' DestTarget.BeforeClean := BeforeCompile;'#013#010+
|
|
|
+ ' DestTarget.AfterClean := AfterClean;'#013#010+
|
|
|
+ ' e','nd'#013#010+
|
|
|
+ ' else'#013#010+
|
|
|
+ ' inherited AssignTo(Dest);'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ 'function TTarget.GetOptions: TStrings;'#013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' If Foptions=Nil then'#013#010+
|
|
|
+ ' FOptions:=TStringList.Create;'#013#010+
|
|
|
+ ' Result:=FOptions;'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ 'function TTarget.GetImportLibFileName(AOS : TOS) : Str','ing;'#013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' result := GetImportLibraryFilename(Name,AOS);'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ 'function TTarget.GetUnitLibFileName: String;'#013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' Result:='#039'libp'#039'+Name+LibExt;'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ 'procedure TTarget.SetOptions(const AValue: TStrings);'#013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' If (AValue=Nil',') or (AValue.Count=0) then'#013#010+
|
|
|
+ ' FreeAndNil(FOptions)'#013#010+
|
|
|
+ ' else'#013#010+
|
|
|
+ ' Options.Assign(AValue);'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ 'function TTarget.GetSourceFileName: String;'#013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' Result:=Name+FExtension;'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ #013#010+
|
|
|
+ 'function TTarget.GetUnitFileName: String;'#013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' ',' Result:=Name+UnitExt;'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ #013#010+
|
|
|
+ 'function TTarget.GetObjectFileName: String;'#013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' Result:=Name+ObjExt;'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ #013#010+
|
|
|
+ 'function TTarget.GetRSTFileName: String;'#013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' Result:=Name+RSText;'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ #013#010+
|
|
|
+ 'function TTarget.GetProgramFileName(A','OS : TOS): String;'#013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' result := AddProgramExtension(Name, AOS);'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ #013#010+
|
|
|
+ 'function TTarget.GetProgramDebugFileName(AOS: TOS): String;'#013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' result := Name + DbgExt;'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ #013#010+
|
|
|
+ 'function TTarget.GetOutputFileName(AOs: TOS): String',';'#013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' if TargetType in UnitTargets then'#013#010+
|
|
|
+ ' Result:=GetUnitFileName'#013#010+
|
|
|
+ ' else'#013#010+
|
|
|
+ ' Result:=GetProgramFileName(AOs);'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ 'function TTarget.HaveOptions: Boolean;'#013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' Result:=(FOptions<>Nil);'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ #013#010+
|
|
|
+ 'procedure TTarget.SetName','(const AValue: String);'#013#010+
|
|
|
+ 'Var'#013#010+
|
|
|
+ ' D,N,E : String;'#013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' N:=FixPath(AValue, False);'#013#010+
|
|
|
+ ' D:=ExtractFilePath(N);'#013#010+
|
|
|
+ ' E:=ExtractFileExt(N);'#013#010+
|
|
|
+ ' N:=ExtractFileName(N);'#013#010+
|
|
|
+ ' inherited SetName(Copy(N,1,Length(N)-Length(E)));'#013#010+
|
|
|
+ ' FExtension:=E;'#013#010+
|
|
|
+ ' FDir','ectory:=D;'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ 'procedure TTarget.SetXML(const AValue: string);'#013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' FXML:=FixPath(AValue, False);'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
'procedure TTarget.GetCleanFiles(List: TStrings; const APrefixU, APrefi'+
|
|
|
- 'xB : String; ACPU: TCPU; AOS : TOS);'#010+
|
|
|
- 'begin'#010+
|
|
|
- ' If not(A','CPU in CPUs) or not(AOS in OSes) then'#010+
|
|
|
- ' exit;'#010+
|
|
|
- ' List.Add(APrefixU + ObjectFileName);'#010+
|
|
|
+ 'xB : String; ACPU: TCPU; AOS : TOS);'#013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' If not','(ACPU in CPUs) or not(AOS in OSes) then'#013#010+
|
|
|
+ ' exit;'#013#010+
|
|
|
+ ' List.Add(APrefixU + ObjectFileName);'#013#010+
|
|
|
' If (TargetType in [ttUnit,ttImplicitUnit,ttExampleUnit, ttCleanOnlyU'+
|
|
|
- 'nit]) then'#010+
|
|
|
- ' begin'#010+
|
|
|
- ' List.Add(APrefixU + UnitFileName);'#010+
|
|
|
- ' if (AOS in AllS','martLinkLibraryOSes) and FileExists(APrefixU + '+
|
|
|
- 'UnitLibFileName) then'#010+
|
|
|
- ' List.Add(APrefixU + UnitLibFileName);'#010+
|
|
|
+ 'nit]) then'#013#010+
|
|
|
+ ' begin'#013#010+
|
|
|
+ ' List.Add(APrefixU + UnitFileName);'#013#010+
|
|
|
+ ' if (AOS',' in AllSmartLinkLibraryOSes) and FileExists(APrefixU + '+
|
|
|
+ 'UnitLibFileName) then'#013#010+
|
|
|
+ ' List.Add(APrefixU + UnitLibFileName);'#013#010+
|
|
|
' if (AOS in AllImportLibraryOSes) and FileExists(APrefixU + GetIm'+
|
|
|
- 'portLibFilename(AOS)) then'#010+
|
|
|
- ' List.Add(APrefixU + ','GetImportLibFilename(AOS));'#010+
|
|
|
- ' end'#010+
|
|
|
- ' else If (TargetType in [ttProgram,ttExampleProgram]) then'#010+
|
|
|
- ' begin'#010+
|
|
|
- ' List.Add(APrefixB + GetProgramFileName(AOS));'#010+
|
|
|
- ' if FileExists(APrefixB + GetProgramDebugFileName(AOS)) then'#010+
|
|
|
- ' List.Add(APref','ixB + GetProgramDebugFileName(AOS));'#010+
|
|
|
- ' end;'#010+
|
|
|
- ' If ResourceStrings then'#010+
|
|
|
- ' List.Add(APrefixU + RSTFileName);'#010+
|
|
|
- ' // Maybe add later ? AddConditionalStrings(List,CleanFiles);'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
- #010+
|
|
|
- 'procedure TTarget.GetInstallFiles(List: TStrings; const APr','efixU, AP'+
|
|
|
- 'refixB: String; ACPU: TCPU; AOS : TOS);'#010+
|
|
|
- 'begin'#010+
|
|
|
+ 'portLibFilename(AOS)) then'#013#010+
|
|
|
+ ' List.Add(','APrefixU + GetImportLibFilename(AOS));'#013#010+
|
|
|
+ ' end'#013#010+
|
|
|
+ ' else If (TargetType in [ttProgram,ttExampleProgram]) then'#013#010+
|
|
|
+ ' begin'#013#010+
|
|
|
+ ' List.Add(APrefixB + GetProgramFileName(AOS));'#013#010+
|
|
|
+ ' if FileExists(APrefixB + GetProgramDebugFileName(AOS)) then'#013#010+
|
|
|
+ ' ',' List.Add(APrefixB + GetProgramDebugFileName(AOS));'#013#010+
|
|
|
+ ' end;'#013#010+
|
|
|
+ ' If ResourceStrings then'#013#010+
|
|
|
+ ' List.Add(APrefixU + RSTFileName);'#013#010+
|
|
|
+ ' // Maybe add later ? AddConditionalStrings(List,CleanFiles);'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ #013#010+
|
|
|
+ 'procedure TTarget.GetInstallFiles(','List: TStrings; const APrefixU, AP'+
|
|
|
+ 'refixB: String; ACPU: TCPU; AOS : TOS);'#013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
' If Not (TargetType in [ttProgram,ttExampleProgram]) and FileExists(A'+
|
|
|
- 'PrefixU + ObjectFileName) then'#010+
|
|
|
- ' // The compiler does not create an objectfile for all programs.'#010+
|
|
|
- ' List.Add(APr','efixU + ObjectFileName);'#010+
|
|
|
- ' If (TargetType in [ttUnit,ttImplicitUnit,ttExampleUnit]) then'#010+
|
|
|
- ' begin'#010+
|
|
|
- ' List.Add(APrefixU + UnitFileName);'#010+
|
|
|
- ' if (AOS in AllSmartLinkLibraryOSes) and FileExists(APrefixU + Unit'+
|
|
|
- 'LibFileName) then'#010+
|
|
|
- ' List.Add','(APrefixU + UnitLibFileName);'#010+
|
|
|
+ 'PrefixU + ObjectFileName) then'#013#010+
|
|
|
+ ' // The compiler does not create an objectfile for al','l programs.'#013+
|
|
|
+ #010+
|
|
|
+ ' List.Add(APrefixU + ObjectFileName);'#013#010+
|
|
|
+ ' If (TargetType in [ttUnit,ttImplicitUnit,ttExampleUnit]) then'#013#010+
|
|
|
+ ' begin'#013#010+
|
|
|
+ ' List.Add(APrefixU + UnitFileName);'#013#010+
|
|
|
+ ' if (AOS in AllSmartLinkLibraryOSes) and FileExists(APrefixU + Uni',
|
|
|
+ 'tLibFileName) then'#013#010+
|
|
|
+ ' List.Add(APrefixU + UnitLibFileName);'#013#010+
|
|
|
' if (AOS in AllImportLibraryOSes) and FileExists(APrefixU + GetImpo'+
|
|
|
- 'rtLibFilename(AOS)) then'#010+
|
|
|
- ' List.Add(APrefixU + GetImportLibFilename(AOS));'#010+
|
|
|
- ' end'#010+
|
|
|
- ' else If (TargetType in [ttProgram,ttExampleProgram]',') then'#010+
|
|
|
- ' List.Add(APrefixB + GetProgramFileName(AOS));'#010+
|
|
|
- ' If ResourceStrings then'#010+
|
|
|
- ' List.Add(APrefixU + RSTFileName);'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
- #010+
|
|
|
- 'procedure TTarget.GetArchiveFiles(List: TStrings; ACPU: TCPU; AOS : TO'+
|
|
|
- 'S);'#010+
|
|
|
- 'var'#010+
|
|
|
- ' i : integer;'#010+
|
|
|
- ' D : TDependency;'#010,
|
|
|
- 'begin'#010+
|
|
|
- ' If not(ACPU in CPUs) or not(AOS in OSes) then'#010+
|
|
|
- ' exit;'#010+
|
|
|
- ' // Main source'#010+
|
|
|
- ' if TargetSourceFileName<>'#039#039' then'#010+
|
|
|
- ' List.Add(TargetSourceFileName);'#010+
|
|
|
- ' // Includes'#010+
|
|
|
- ' for i:=0 to Dependencies.Count-1 do'#010+
|
|
|
- ' begin'#010+
|
|
|
- ' D:=Dependencies[i];'#010,
|
|
|
- ' if (D.DependencyType=depInclude) and'#010+
|
|
|
- ' (D.TargetFileName<>'#039#039') then'#010+
|
|
|
- ' List.Add(D.TargetFileName);'#010+
|
|
|
- ' end;'#010+
|
|
|
- ' // FPDoc files'#010+
|
|
|
- ' if XML <> '#039#039' then'#010+
|
|
|
- ' begin'#010+
|
|
|
- ' List.Add(Directory + Name + Extension);'#010+
|
|
|
- ' List.Add(XML);'#010+
|
|
|
- ' end;'#010,
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
- #010+
|
|
|
+ 'rtLibFilename(AOS)) then'#013#010+
|
|
|
+ ' List.Add(APrefixU + GetImportLibFilename(AOS));'#013#010+
|
|
|
+ ' end'#013#010+
|
|
|
+ ' else If (Targ','etType in [ttProgram,ttExampleProgram]) then'#013#010+
|
|
|
+ ' List.Add(APrefixB + GetProgramFileName(AOS));'#013#010+
|
|
|
+ ' If ResourceStrings then'#013#010+
|
|
|
+ ' List.Add(APrefixU + RSTFileName);'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ #013#010+
|
|
|
+ 'procedure TTarget.GetArchiveFiles(List: TStrings; ACPU: TCPU; AOS :',' '+
|
|
|
+ 'TOS);'#013#010+
|
|
|
+ 'var'#013#010+
|
|
|
+ ' i : integer;'#013#010+
|
|
|
+ ' D : TDependency;'#013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' If not(ACPU in CPUs) or not(AOS in OSes) then'#013#010+
|
|
|
+ ' exit;'#013#010+
|
|
|
+ ' // Main source'#013#010+
|
|
|
+ ' if TargetSourceFileName<>'#039#039' then'#013#010+
|
|
|
+ ' List.Add(TargetSourceFileName);'#013#010+
|
|
|
+ ' // Includes'#013#010+
|
|
|
+ ' for i:=0 to Depe','ndencies.Count-1 do'#013#010+
|
|
|
+ ' begin'#013#010+
|
|
|
+ ' D:=Dependencies[i];'#013#010+
|
|
|
+ ' if (D.DependencyType=depInclude) and'#013#010+
|
|
|
+ ' (D.TargetFileName<>'#039#039') then'#013#010+
|
|
|
+ ' List.Add(D.TargetFileName);'#013#010+
|
|
|
+ ' end;'#013#010+
|
|
|
+ ' // FPDoc files'#013#010+
|
|
|
+ ' if XML <> '#039#039' then'#013#010+
|
|
|
+ ' begin'#013#010+
|
|
|
+ ' ','List.Add(Directory + Name + Extension);'#013#010+
|
|
|
+ ' List.Add(XML);'#013#010+
|
|
|
+ ' end;'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ #013#010+
|
|
|
'{*********************************************************************'+
|
|
|
- '*******'#010+
|
|
|
- ' TSource'#010+
|
|
|
+ '*******'#013#010+
|
|
|
+ ' TSource'#013#010+
|
|
|
+ '****************************************','****************************'+
|
|
|
+ '********}'#013#010+
|
|
|
+ #013#010+
|
|
|
+ 'function TSource.GetInstallSourcePath: string;'#013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' if FInstallSourcePath<>'#039#039' then'#013#010+
|
|
|
+ ' result := FInstallSourcePath'#013#010+
|
|
|
+ ' else if SourceType=stExample then'#013#010+
|
|
|
+ ' result := '#039'examples'#039#013#010+
|
|
|
+ ' else'#013#010+
|
|
|
+ ' r','esult := '#039#039';'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ 'constructor TSource.Create(ACollection: TCollection);'#013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' inherited Create(ACollection);'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ #013#010+
|
|
|
+ 'destructor TSource.Destroy;'#013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' inherited Destroy;'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ 'procedure TSource.GetInstallFiles(List: TStrin','gs);'#013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' if InstallSourcePath<>'#039#039' then'#013#010+
|
|
|
+ ' list.Values[name] := (IncludeTrailingPathDelimiter(InstallSourcePa'+
|
|
|
+ 'th)+ExtractFileName(Name))'#013#010+
|
|
|
+ ' else'#013#010+
|
|
|
+ ' list.add(Name);'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ #013#010+
|
|
|
+ '{********************************************************','***********'+
|
|
|
+ '*********'#013#010+
|
|
|
+ ' TCommands'#013#010+
|
|
|
'**********************************************************************'+
|
|
|
- '******}'#010+
|
|
|
- #010+
|
|
|
- 'function TSource.GetInstallSourcePa','th: string;'#010+
|
|
|
- 'begin'#010+
|
|
|
- ' if FInstallSourcePath<>'#039#039' then'#010+
|
|
|
- ' result := FInstallSourcePath'#010+
|
|
|
- ' else if SourceType=stExample then'#010+
|
|
|
- ' result := '#039'examples'#039#010+
|
|
|
- ' else'#010+
|
|
|
- ' result := '#039#039';'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
- 'constructor TSource.Create(ACollection: TCollection);'#010+
|
|
|
- 'begin'#010+
|
|
|
- ' in','herited Create(ACollection);'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
- #010+
|
|
|
- 'destructor TSource.Destroy;'#010+
|
|
|
- 'begin'#010+
|
|
|
- ' inherited Destroy;'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
- 'procedure TSource.GetInstallFiles(List: TStrings);'#010+
|
|
|
- 'begin'#010+
|
|
|
- ' if InstallSourcePath<>'#039#039' then'#010+
|
|
|
- ' list.Values[name] := (IncludeTrailingPathDelimiter','(InstallSource'+
|
|
|
- 'Path)+ExtractFileName(Name))'#010+
|
|
|
- ' else'#010+
|
|
|
- ' list.add(Name);'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
- #010+
|
|
|
- '{*********************************************************************'+
|
|
|
- '*******'#010+
|
|
|
- ' TCommands'#010+
|
|
|
- '******************************************','**************************'+
|
|
|
- '********}'#010+
|
|
|
- #010+
|
|
|
- 'function TCommands.GetCommand(const Dest : String): TCommand;'#010+
|
|
|
- 'begin'#010+
|
|
|
- ' Result:=TCommand(ItemByName(Dest));'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
- 'function TCommands.GetCommandItem(Index : Integer): TCommand;'#010+
|
|
|
- 'begin'#010+
|
|
|
- ' Result:=TCommand(Item','s[Index]);'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
- #010+
|
|
|
+ '******}'#013#010+
|
|
|
+ #013#010+
|
|
|
+ 'function TCommands.GetCommand(const Dest : String): TCommand;'#013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' Result:=TCommand(Item','ByName(Dest));'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ 'function TCommands.GetCommandItem(Index : Integer): TCommand;'#013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' Result:=TCommand(Items[Index]);'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ #013#010+
|
|
|
'procedure TCommands.SetCommandItem(Index : Integer; const AValue: TCom'+
|
|
|
- 'mand);'#010+
|
|
|
- 'begin'#010+
|
|
|
- ' Items[Index]:=AValue;'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
- #010+
|
|
|
- 'Function TCommands.AddCommand(const Cmd: String) : TCommand;'#010+
|
|
|
- 'begin'#010+
|
|
|
- ' Result:=AddCommand(fdefaultAt,Cmd,'#039#039','#039#039,','#039#039');'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
- #010+
|
|
|
- 'function TCommands.AddCommand(const Cmd, Options: String): TCommand;'#010+
|
|
|
- 'begin'#010+
|
|
|
- ' Result:=AddCommand(fdefaultAt,Cmd,Options,'#039#039','#039#039');'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
- #010+
|
|
|
+ 'mand);'#013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' Items[Index]:=','AValue;'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ #013#010+
|
|
|
+ 'Function TCommands.AddCommand(const Cmd: String) : TCommand;'#013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' Result:=AddCommand(fdefaultAt,Cmd,'#039#039','#039#039','#039#039');'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ #013#010+
|
|
|
+ 'function TCommands.AddCommand(const Cmd, Options: String): TCommand;'#013+
|
|
|
+ #010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' Result:=AddComm','and(fdefaultAt,Cmd,Options,'#039#039','#039#039');'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ #013#010+
|
|
|
'function TCommands.AddCommand(const Cmd, Options, Dest, Source: String'+
|
|
|
- ' ): TCommand;'#010+
|
|
|
- 'begin'#010+
|
|
|
- ' R','esult:=AddCommand(fdefaultAt,Cmd,options,Dest,Source);'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
- #010+
|
|
|
- 'Function TCommands.AddCommand(At: TCommandAt; const Cmd: String) : TCo'+
|
|
|
- 'mmand;'#010+
|
|
|
- 'begin'#010+
|
|
|
- ' Result:=AddCommand(At,Cmd,'#039#039','#039#039','#039#039');'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
- #010+
|
|
|
- 'function TCommands.AddCommand(At: TCommandAt; con','st Cmd, Options: St'+
|
|
|
- 'ring ): TCommand;'#010+
|
|
|
- 'begin'#010+
|
|
|
- ' Result:=AddCommand(At,Cmd,Options,'#039#039','#039#039');'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
- #010+
|
|
|
+ ' ): TCommand;'#013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' Result:=AddCommand(fdefaultAt,Cmd,options,Dest,Source);'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ #013#010+
|
|
|
+ 'Function TCommands.AddCommand(At:',' TCommandAt; const Cmd: String) : T'+
|
|
|
+ 'Command;'#013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' Result:=AddCommand(At,Cmd,'#039#039','#039#039','#039#039');'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ #013#010+
|
|
|
+ 'function TCommands.AddCommand(At: TCommandAt; const Cmd, Options: Stri'+
|
|
|
+ 'ng ): TCommand;'#013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' Result:=AddCommand(At,Cmd,Options,'#039#039','#039#039');',#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ #013#010+
|
|
|
'function TCommands.AddCommand(At: TCommandAt; const Cmd, Options, Dest'+
|
|
|
- ', Source: String): TCommand;'#010+
|
|
|
- 'begin'#010+
|
|
|
- ' Result:=Add as TCommand;'#010+
|
|
|
- ' Result.Comm','and:=Cmd;'#010+
|
|
|
- ' If (Options<>'#039#039') then'#010+
|
|
|
- ' Result.ParseOptions(Options);'#010+
|
|
|
- ' Result.At:=At;'#010+
|
|
|
- ' Result.SourceFile:=Source;'#010+
|
|
|
- ' Result.DestFile:=Dest;'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
- #010+
|
|
|
+ ', Source: String): TCommand;'#013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' Result:=Add as TCommand;'#013#010+
|
|
|
+ ' Result.Command:=Cmd;'#013#010+
|
|
|
+ ' If (Options<>'#039#039') then'#013#010+
|
|
|
+ ' Result.ParseOptions(Options);'#013#010+
|
|
|
+ ' Result.','At:=At;'#013#010+
|
|
|
+ ' Result.SourceFile:=Source;'#013#010+
|
|
|
+ ' Result.DestFile:=Dest;'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ #013#010+
|
|
|
'{*********************************************************************'+
|
|
|
- '*******'#010+
|
|
|
- ' ',' TConditionalString'#010+
|
|
|
- '**********************************************************************'+
|
|
|
- '******}'#010+
|
|
|
- #010+
|
|
|
- 'Constructor TConditionalString.Create;'#010+
|
|
|
- 'begin'#010+
|
|
|
- ' inherited Create;'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
- #010+
|
|
|
- '{**********************************************************','*********'+
|
|
|
- '*********'#010+
|
|
|
- ' TConditionalStrings'#010+
|
|
|
+ '*******'#013#010+
|
|
|
+ ' TConditionalString'#013#010+
|
|
|
+ '***************************************','*****************************'+
|
|
|
+ '********}'#013#010+
|
|
|
+ #013#010+
|
|
|
+ 'Constructor TConditionalString.Create;'#013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' inherited Create;'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ #013#010+
|
|
|
+ '{*********************************************************************'+
|
|
|
+ '*******'#013#010+
|
|
|
+ ' TConditionalSt','rings'#013#010+
|
|
|
'**********************************************************************'+
|
|
|
- '******}'#010+
|
|
|
- #010+
|
|
|
+ '******}'#013#010+
|
|
|
+ #013#010+
|
|
|
'Constructor TConditionalStrings.Create(AClass:TConditionalStringClass)'+
|
|
|
- ';'#010+
|
|
|
- 'begin'#010+
|
|
|
- ' inherited Creat','e;'#010+
|
|
|
- ' FCSClass:=AClass;'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
- #010+
|
|
|
- 'function TConditionalStrings.GetConditionalString(Index : Integer): TC'+
|
|
|
- 'onditionalString;'#010+
|
|
|
- 'begin'#010+
|
|
|
- ' Result:=TConditionalString(Items[Index]);'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
- #010+
|
|
|
- 'procedure TConditionalStrings.SetConditionalString(Index : Intege','r; '+
|
|
|
- 'const AValue: TConditionalString);'#010+
|
|
|
- 'begin'#010+
|
|
|
- ' Items[Index]:=AValue;'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
- #010+
|
|
|
+ ';'#013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' inherited Create;'#013#010+
|
|
|
+ ' FCSClass:=AClass;'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ #013#010+
|
|
|
+ 'function TConditiona','lStrings.GetConditionalString(Index : Integer): '+
|
|
|
+ 'TConditionalString;'#013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' Result:=TConditionalString(Items[Index]);'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ #013#010+
|
|
|
+ 'procedure TConditionalStrings.SetConditionalString(Index : Integer; co'+
|
|
|
+ 'nst AValue: TConditionalString);'#013#010+
|
|
|
+ 'begin',#013#010+
|
|
|
+ ' Items[Index]:=AValue;'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ #013#010+
|
|
|
'Function TConditionalStrings.Add(Const Value : String) : TConditionalS'+
|
|
|
- 'tring;'#010+
|
|
|
- 'begin'#010+
|
|
|
- ' result:=Add(Value,AllCPUs,AllOSes);'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
- #010+
|
|
|
- '{$ifdef cpu_only_overloads}'#010+
|
|
|
- 'Function ','TConditionalStrings.Add(Const Value : String;const CPUs:TCP'+
|
|
|
- 'Us) : TConditionalString;'#010+
|
|
|
- 'begin'#010+
|
|
|
- ' result:=Add(Value,CPUs,AllOSes);'#010+
|
|
|
- 'end;'#010+
|
|
|
- '{$endif cpu_only_overloads}'#010+
|
|
|
- #010+
|
|
|
- #010+
|
|
|
+ 'tring;'#013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' result:=Add(Value,AllCPUs,AllOSes);'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ #013#010+
|
|
|
+ '{$ifdef cpu_only_overloads}'#013#010+
|
|
|
+ 'Function TConditionalStrings.Add(Const V','alue : String;const CPUs:TCP'+
|
|
|
+ 'Us) : TConditionalString;'#013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' result:=Add(Value,CPUs,AllOSes);'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ '{$endif cpu_only_overloads}'#013#010+
|
|
|
+ #013#010+
|
|
|
+ #013#010+
|
|
|
'Function TConditionalStrings.Add(Const Value : String;const OSes:TOSes'+
|
|
|
- ') : TCond','itionalString;'#010+
|
|
|
- 'begin'#010+
|
|
|
- ' result:=Add(Value,AllCPUs,OSes);'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
- #010+
|
|
|
+ ') : TConditionalString;'#013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' ',' result:=Add(Value,AllCPUs,OSes);'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ #013#010+
|
|
|
'Function TConditionalStrings.Add(Const Value : String;const CPUs:TCPUs'+
|
|
|
- ';const OSes:TOSes) : TConditionalString;'#010+
|
|
|
- 'begin'#010+
|
|
|
- ' Result:=FCSClass.Create;'#010+
|
|
|
- ' Result.Value:=Value;'#010+
|
|
|
- ' Result.O','Ses:=OSes;'#010+
|
|
|
- ' Result.CPUs:=CPUs;'#010+
|
|
|
- ' inherited Add(Result);'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
- #010+
|
|
|
+ ';const OSes:TOSes) : TConditionalString;'#013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' Result:=FCSClass.Create;'#013#010+
|
|
|
+ ' Result.Value:=Value;'#013#010+
|
|
|
+ ' Result.OSes:=OSes;'#013#010+
|
|
|
+ ' ','Result.CPUs:=CPUs;'#013#010+
|
|
|
+ ' inherited Add(Result);'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ #013#010+
|
|
|
'{*********************************************************************'+
|
|
|
- '*******'#010+
|
|
|
- ' TDependency'#010+
|
|
|
- '******************************************************','**************'+
|
|
|
- '********}'#010+
|
|
|
- #010+
|
|
|
- 'Constructor TDependency.Create;'#010+
|
|
|
- 'begin'#010+
|
|
|
- ' inherited Create;'#010+
|
|
|
- ' FVersion:=TFPVersion.Create;'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
- #010+
|
|
|
- 'Destructor TDependency.Destroy;'#010+
|
|
|
- 'begin'#010+
|
|
|
- ' FreeAndNil(FVersion);'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
- #010+
|
|
|
- 'Function TDependency.GetVersion : string;'#010+
|
|
|
- 'begin'#010+
|
|
|
- ' ','result:=FVersion.AsString;'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
- #010+
|
|
|
- 'Procedure TDependency.SetVersion(const V : string);'#010+
|
|
|
- 'begin'#010+
|
|
|
- ' FVersion.AsString:=V;'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
- #010+
|
|
|
+ '*******'#013#010+
|
|
|
+ ' TDependency'#013#010+
|
|
|
+ '************************************************************','********'+
|
|
|
+ '********}'#013#010+
|
|
|
+ #013#010+
|
|
|
+ 'Constructor TDependency.Create;'#013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' inherited Create;'#013#010+
|
|
|
+ ' FVersion:=TFPVersion.Create;'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ #013#010+
|
|
|
+ 'Destructor TDependency.Destroy;'#013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' FreeAndNil(FVersion);'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ #013#010+
|
|
|
+ 'Function TDependency.GetVersion : string;',#013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' result:=FVersion.AsString;'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ #013#010+
|
|
|
+ 'Procedure TDependency.SetVersion(const V : string);'#013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' FVersion.AsString:=V;'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ #013#010+
|
|
|
'{*********************************************************************'+
|
|
|
- '*******'#010+
|
|
|
- ' TDepend','encies'#010+
|
|
|
+ '*******'#013#010+
|
|
|
+ ' ',' TDependencies'#013#010+
|
|
|
'**********************************************************************'+
|
|
|
- '******}'#010+
|
|
|
- #010+
|
|
|
- 'function TDependencies.GetDependency(Index : Integer): TDependency;'#010+
|
|
|
- 'begin'#010+
|
|
|
- ' Result:=TDependency(Items[Index]);'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
- #010+
|
|
|
- 'procedure TDependencies.SetDependenc','y(Index : Integer; const AValue:'+
|
|
|
- ' TDependency);'#010+
|
|
|
- 'begin'#010+
|
|
|
- ' Items[Index]:=AValue;'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
- #010+
|
|
|
- 'Function TDependencies.Add(Const Value : String) : TDependency;'#010+
|
|
|
- 'begin'#010+
|
|
|
- ' result:=Add(Value,AllCPUs,AllOSes);'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
- #010+
|
|
|
- '{$ifdef cpu_only_overloads}'#010+
|
|
|
- 'Function TDep','endencies.Add(Const Value : String;const CPUs:TCPUs) : '+
|
|
|
- 'TDependency;'#010+
|
|
|
- 'begin'#010+
|
|
|
- ' result:=Add(Value,CPUs,AllOSes);'#010+
|
|
|
- 'end;'#010+
|
|
|
- '{$endif cpu_only_overloads}'#010+
|
|
|
- #010+
|
|
|
- #010+
|
|
|
- 'Function TDependencies.Add(Const Value : String;const OSes:TOSes) : TD'+
|
|
|
- 'ependency;'#010+
|
|
|
- 'begin'#010+
|
|
|
- ' result:','=Add(Value,AllCPUs,OSes);'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
- #010+
|
|
|
+ '******}'#013#010+
|
|
|
+ #013#010+
|
|
|
+ 'function TDependencies.GetDependency(Index : Integer): TDependency;'#013+
|
|
|
+ #010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' Result:=TDependency(Items[Index]);'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ #013#010+
|
|
|
+ 'proce','dure TDependencies.SetDependency(Index : Integer; const AValue:'+
|
|
|
+ ' TDependency);'#013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' Items[Index]:=AValue;'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ #013#010+
|
|
|
+ 'Function TDependencies.Add(Const Value : String) : TDependency;'#013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' result:=Add(Value,AllCPUs,AllOSes);'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010,
|
|
|
+ #013#010+
|
|
|
+ '{$ifdef cpu_only_overloads}'#013#010+
|
|
|
+ 'Function TDependencies.Add(Const Value : String;const CPUs:TCPUs) : TD'+
|
|
|
+ 'ependency;'#013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' result:=Add(Value,CPUs,AllOSes);'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ '{$endif cpu_only_overloads}'#013#010+
|
|
|
+ #013#010+
|
|
|
+ #013#010+
|
|
|
+ 'Function TDependencies.Add(Const Value : Stri','ng;const OSes:TOSes) : '+
|
|
|
+ 'TDependency;'#013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' result:=Add(Value,AllCPUs,OSes);'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ #013#010+
|
|
|
'Function TDependencies.Add(Const Value : String;const CPUs:TCPUs;const'+
|
|
|
- ' OSes:TOSes) : TDependency;'#010+
|
|
|
- 'begin'#010+
|
|
|
- ' Result:=inherited Add(Value,CPUs,OSes) as TDependency;'#010+
|
|
|
- ' Result.Target:=nil;'#010+
|
|
|
- ' Result.FDependencyType',':=depPackage;'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
- #010+
|
|
|
- 'Function TDependencies.AddUnit(Const Value : String) : TDependency;'#010+
|
|
|
- 'begin'#010+
|
|
|
- ' result:=AddUnit(Value,AllCPUs,AllOSes);'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
- #010+
|
|
|
- '{$ifdef cpu_only_overloads}'#010+
|
|
|
- 'Function TDependencies.AddUnit(Const Value : String;const CPUs:TCPUs',')'+
|
|
|
- ' : TDependency;'#010+
|
|
|
- 'begin'#010+
|
|
|
- ' result:=AddUnit(Value,CPUs,AllOSes);'#010+
|
|
|
- 'end;'#010+
|
|
|
- '{$endif cpu_only_overloads}'#010+
|
|
|
- #010+
|
|
|
- #010+
|
|
|
- 'Function TDependencies.AddUnit(Const Value : String;const OSes:TOSes) '+
|
|
|
- ': TDependency;'#010+
|
|
|
- 'begin'#010+
|
|
|
- ' result:=AddUnit(Value,AllCPUs,OSes);'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
- #010+
|
|
|
- 'Functi','on TDependencies.AddUnit(Const Value : String;const CPUs:TCPUs'+
|
|
|
- ';const OSes:TOSes) : TDependency;'#010+
|
|
|
- 'begin'#010+
|
|
|
- ' Result:=inherited Add(Value,CPUs,OSes) as TDependency;'#010+
|
|
|
- ' Result.Target:=nil;'#010+
|
|
|
- ' Result.FDependencyType:=depUnit;'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
- #010+
|
|
|
- 'Function TDepende','ncies.AddInclude(Const Value : String) : TDependenc'+
|
|
|
- 'y;'#010+
|
|
|
- 'begin'#010+
|
|
|
- ' result:=AddInclude(Value,AllCPUs,AllOSes);'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
- #010+
|
|
|
- '{$ifdef cpu_only_overloads}'#010+
|
|
|
+ ' OSes:TOSes) : TDependency;'#013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' Result:=inherited Add(Value,CPUs,OSes) as ','TDependency;'#013#010+
|
|
|
+ ' Result.Target:=nil;'#013#010+
|
|
|
+ ' Result.FDependencyType:=depPackage;'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ #013#010+
|
|
|
+ 'Function TDependencies.AddUnit(Const Value : String) : TDependency;'#013+
|
|
|
+ #010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' result:=AddUnit(Value,AllCPUs,AllOSes);'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ #013#010+
|
|
|
+ '{$ifdef cpu_only_overload','s}'#013#010+
|
|
|
+ 'Function TDependencies.AddUnit(Const Value : String;const CPUs:TCPUs) '+
|
|
|
+ ': TDependency;'#013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' result:=AddUnit(Value,CPUs,AllOSes);'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ '{$endif cpu_only_overloads}'#013#010+
|
|
|
+ #013#010+
|
|
|
+ #013#010+
|
|
|
+ 'Function TDependencies.AddUnit(Const Value : String;const OSes:T','OSes'+
|
|
|
+ ') : TDependency;'#013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' result:=AddUnit(Value,AllCPUs,OSes);'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ #013#010+
|
|
|
+ 'Function TDependencies.AddUnit(Const Value : String;const CPUs:TCPUs;c'+
|
|
|
+ 'onst OSes:TOSes) : TDependency;'#013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' Result:=inherited Add(Value,CPUs,OSes) as TDepend','ency;'#013#010+
|
|
|
+ ' Result.Target:=nil;'#013#010+
|
|
|
+ ' Result.FDependencyType:=depUnit;'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ #013#010+
|
|
|
+ 'Function TDependencies.AddInclude(Const Value : String) : TDependency;'+
|
|
|
+ #013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' result:=AddInclude(Value,AllCPUs,AllOSes);'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ #013#010+
|
|
|
+ '{$ifdef cpu_only_overloads}'#013#010,
|
|
|
'Function TDependencies.AddInclude(Const Value : String;const CPUs:TCPU'+
|
|
|
- 's) : TDependency;'#010+
|
|
|
- 'begin'#010+
|
|
|
- ' resu','lt:=AddInclude(Value,CPUs,AllOSes);'#010+
|
|
|
- 'end;'#010+
|
|
|
- '{$endif cpu_only_overloads}'#010+
|
|
|
- #010+
|
|
|
- #010+
|
|
|
- 'Function TDependencies.AddInclude(Const Value : String;const OSes:TOSe'+
|
|
|
- 's) : TDependency;'#010+
|
|
|
- 'begin'#010+
|
|
|
- ' result:=AddInclude(Value,AllCPUs,OSes);'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
- #010+
|
|
|
- 'Function TDependencies.Add','Include(Const Value : String;const CPUs:TC'+
|
|
|
- 'PUs;const OSes:TOSes) : TDependency;'#010+
|
|
|
- 'Var'#010+
|
|
|
- ' N : String;'#010+
|
|
|
- 'begin'#010+
|
|
|
- ' N:=FixPath(Value, False);'#010+
|
|
|
- ' if ExtractFileExt(N)='#039#039' then'#010+
|
|
|
- ' ChangeFileExt(N,IncExt);'#010+
|
|
|
- ' Result:=inherited Add(N,CPUs,OSes) as TDependen','cy;'#010+
|
|
|
- ' Result.FDependencyType:=depInclude;'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
- #010+
|
|
|
- '{*********************************************************************'+
|
|
|
- '*******'#010+
|
|
|
- ' TValueItem'#010+
|
|
|
+ 's) : TDependency;'#013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' result:=AddInclude(Value,CPUs,AllOSes);'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ '{$endif cpu_only_overloads}'#013#010+
|
|
|
+ #013#010+
|
|
|
+ #013#010+
|
|
|
+ 'Function TDependencies.AddInclude(Const Value : String;const O','Ses:TO'+
|
|
|
+ 'Ses) : TDependency;'#013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' result:=AddInclude(Value,AllCPUs,OSes);'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ #013#010+
|
|
|
+ 'Function TDependencies.AddInclude(Const Value : String;const CPUs:TCPU'+
|
|
|
+ 's;const OSes:TOSes) : TDependency;'#013#010+
|
|
|
+ 'Var'#013#010+
|
|
|
+ ' N : String;'#013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' N:=FixPath(Value, ','False);'#013#010+
|
|
|
+ ' if ExtractFileExt(N)='#039#039' then'#013#010+
|
|
|
+ ' ChangeFileExt(N,IncExt);'#013#010+
|
|
|
+ ' Result:=inherited Add(N,CPUs,OSes) as TDependency;'#013#010+
|
|
|
+ ' Result.FDependencyType:=depInclude;'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ #013#010+
|
|
|
+ '{*****************************************************************','**'+
|
|
|
+ '*********'#013#010+
|
|
|
+ ' TValueItem'#013#010+
|
|
|
'**********************************************************************'+
|
|
|
- '*','*****}'#010+
|
|
|
- #010+
|
|
|
- 'constructor TValueItem.Create(AValue: String);'#010+
|
|
|
- 'begin'#010+
|
|
|
- ' FValue:=AValue;'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
- #010+
|
|
|
- '{*********************************************************************'+
|
|
|
- '*******'#010+
|
|
|
- ' TFunctionItem'#010+
|
|
|
- '********************************','************************************'+
|
|
|
- '********}'#010+
|
|
|
- #010+
|
|
|
- 'constructor TFunctionItem.Create(AFunc: TReplaceFunction);'#010+
|
|
|
- 'begin'#010+
|
|
|
- ' FFunc:=AFunc;'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
- #010+
|
|
|
+ '******}'#013#010+
|
|
|
+ #013#010+
|
|
|
+ 'constructor TValueItem.Create(AValue: String);'#013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' FValue:=AValue;'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ #013#010+
|
|
|
+ '{******************','*************************************************'+
|
|
|
+ '*********'#013#010+
|
|
|
+ ' TFunctionItem'#013#010+
|
|
|
+ '**********************************************************************'+
|
|
|
+ '******}'#013#010+
|
|
|
+ #013#010+
|
|
|
+ 'constructor TFunctionItem.Create(AFunc: TReplaceFuncti','on);'#013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' FFunc:=AFunc;'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ #013#010+
|
|
|
'{*********************************************************************'+
|
|
|
- '*******'#010+
|
|
|
- ' ',' TDictionary'#010+
|
|
|
+ '*******'#013#010+
|
|
|
+ ' TDictionary'#013#010+
|
|
|
'**********************************************************************'+
|
|
|
- '******}'#010+
|
|
|
- #010+
|
|
|
- 'constructor TDictionary.Create(AOwner: TComponent);'#010+
|
|
|
- 'begin'#010+
|
|
|
- ' inherited Create(AOwner);'#010+
|
|
|
- ' FList:=TStringList.Create;'#010+
|
|
|
- ' FList.Sorted:=True;'#010+
|
|
|
- ' FLis','t.Duplicates:=dupError;'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
- #010+
|
|
|
- 'destructor TDictionary.Destroy;'#010+
|
|
|
- 'Var'#010+
|
|
|
- ' I : Integer;'#010+
|
|
|
- 'begin'#010+
|
|
|
- ' For I:=0 to Flist.Count-1 do'#010+
|
|
|
- ' FList.Objects[i].Free;'#010+
|
|
|
- ' FreeAndNil(FList);'#010+
|
|
|
- ' inherited Destroy;'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
- #010+
|
|
|
- 'procedure TDictionary.AddVariable(const AName',', Value: String);'#010+
|
|
|
- 'Var'#010+
|
|
|
- ' I : Integer;'#010+
|
|
|
- 'begin'#010+
|
|
|
- ' I:=Flist.IndexOf(AName);'#010+
|
|
|
- ' If I=-1 then'#010+
|
|
|
- ' I:=FList.Add(Aname)'#010+
|
|
|
- ' else'#010+
|
|
|
- ' Flist.Objects[i].Free;'#010+
|
|
|
- ' Flist.Objects[i]:=TValueItem.Create(Value);'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
- #010+
|
|
|
- 'procedure TDictionary.AddFunction(const ANam','e: String; FReplacement:'+
|
|
|
- ' TReplaceFunction);'#010+
|
|
|
- 'Var'#010+
|
|
|
- ' I : Integer;'#010+
|
|
|
- 'begin'#010+
|
|
|
- ' I:=Flist.IndexOf(AName);'#010+
|
|
|
- ' If I=-1 then'#010+
|
|
|
- ' I:=Flist.Add(AName)'#010+
|
|
|
- ' else'#010+
|
|
|
- ' Flist.Objects[i].Free;'#010+
|
|
|
- ' Flist.Objects[i]:=TFunctionItem.Create(FReplacement);'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
- #010+
|
|
|
- 'procedur','e TDictionary.RemoveItem(const AName: String);'#010+
|
|
|
- 'Var'#010+
|
|
|
- ' I : Integer;'#010+
|
|
|
- 'begin'#010+
|
|
|
- ' I:=Flist.IndexOf(AName);'#010+
|
|
|
- ' If (I<>-1) then'#010+
|
|
|
- ' begin'#010+
|
|
|
- ' FList.Objects[i].Free;'#010+
|
|
|
- ' FList.Delete(I);'#010+
|
|
|
- ' end;'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
- #010+
|
|
|
- 'function TDictionary.GetValue(AName: String): Str','ing;'#010+
|
|
|
- 'begin'#010+
|
|
|
- ' Result:=GetValue(AName,'#039#039');'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
- #010+
|
|
|
- 'function TDictionary.GetValue(const AName,Args: String): String;'#010+
|
|
|
- 'Var'#010+
|
|
|
- ' O : TObject;'#010+
|
|
|
- ' I : Integer;'#010+
|
|
|
- 'begin'#010+
|
|
|
- ' I:=Flist.IndexOf(AName);'#010+
|
|
|
- ' If (I=-1) then'#010+
|
|
|
- ' Raise EDictionaryError.CreateFmt(SErrNo','DictionaryItem,[AName]);'#010+
|
|
|
- ' O:=Flist.Objects[I];'#010+
|
|
|
- ' If O is TValueItem then'#010+
|
|
|
- ' Result:=TValueItem(O).FValue'#010+
|
|
|
- ' else'#010+
|
|
|
- ' Result:=TFunctionItem(O).FFunc(AName,Args);'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
- #010+
|
|
|
- 'function TDictionary.ReplaceStrings(Const ASource: String): String;'#010+
|
|
|
- 'Var',#010+
|
|
|
- ' S,FN,FV : String;'#010+
|
|
|
- ' P: Integer;'#010+
|
|
|
- 'begin'#010+
|
|
|
- ' Result:='#039#039';'#010+
|
|
|
- ' S:=ASource;'#010+
|
|
|
- ' P:=Pos('#039'$('#039',S);'#010+
|
|
|
- ' While (P<>0) do'#010+
|
|
|
- ' begin'#010+
|
|
|
- ' Result:=Result+Copy(S,1,P-1);'#010+
|
|
|
- ' Delete(S,1,P+1);'#010+
|
|
|
- ' P:=Pos('#039')'#039',S);'#010+
|
|
|
- ' FN:=Copy(S,1,P-1);'#010+
|
|
|
- ' Delete(S,1,P);',#010+
|
|
|
- ' P:=Pos('#039' '#039',FN);'#010+
|
|
|
- ' If (P<>0) then // function arguments ?'#010+
|
|
|
- ' begin'#010+
|
|
|
- ' FV:=FN;'#010+
|
|
|
- ' FN:=Copy(FN,1,P);'#010+
|
|
|
- ' System.Delete(FV,1,P);'#010+
|
|
|
- ' end'#010+
|
|
|
- ' else'#010+
|
|
|
- ' FV:='#039#039';'#010+
|
|
|
- ' Result:=Result+GetValue(FN,FV);'#010+
|
|
|
- ' P:','=Pos('#039'$('#039',S);'#010+
|
|
|
- ' end;'#010+
|
|
|
- ' Result:=Result+S;'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
- #010+
|
|
|
+ '*****','*}'#013#010+
|
|
|
+ #013#010+
|
|
|
+ 'constructor TDictionary.Create(AOwner: TComponent);'#013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' inherited Create(AOwner);'#013#010+
|
|
|
+ ' FList:=TStringList.Create;'#013#010+
|
|
|
+ ' FList.Sorted:=True;'#013#010+
|
|
|
+ ' FList.Duplicates:=dupError;'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ #013#010+
|
|
|
+ 'destructor TDictionary.Destroy;'#013#010+
|
|
|
+ 'Var'#013#010+
|
|
|
+ ' I : Integer',';'#013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' For I:=0 to Flist.Count-1 do'#013#010+
|
|
|
+ ' FList.Objects[i].Free;'#013#010+
|
|
|
+ ' FreeAndNil(FList);'#013#010+
|
|
|
+ ' inherited Destroy;'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ #013#010+
|
|
|
+ 'procedure TDictionary.AddVariable(const AName, Value: String);'#013#010+
|
|
|
+ 'Var'#013#010+
|
|
|
+ ' I : Integer;'#013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' I:=Flist.IndexOf(AName',');'#013#010+
|
|
|
+ ' If I=-1 then'#013#010+
|
|
|
+ ' I:=FList.Add(Aname)'#013#010+
|
|
|
+ ' else'#013#010+
|
|
|
+ ' Flist.Objects[i].Free;'#013#010+
|
|
|
+ ' Flist.Objects[i]:=TValueItem.Create(Value);'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ #013#010+
|
|
|
+ 'procedure TDictionary.AddFunction(const AName: String; FReplacement: T'+
|
|
|
+ 'ReplaceFunction);'#013#010+
|
|
|
+ 'Var'#013#010+
|
|
|
+ ' I : In','teger;'#013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' I:=Flist.IndexOf(AName);'#013#010+
|
|
|
+ ' If I=-1 then'#013#010+
|
|
|
+ ' I:=Flist.Add(AName)'#013#010+
|
|
|
+ ' else'#013#010+
|
|
|
+ ' Flist.Objects[i].Free;'#013#010+
|
|
|
+ ' Flist.Objects[i]:=TFunctionItem.Create(FReplacement);'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ #013#010+
|
|
|
+ 'procedure TDictionary.RemoveItem(const AName: String)',';'#013#010+
|
|
|
+ 'Var'#013#010+
|
|
|
+ ' I : Integer;'#013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' I:=Flist.IndexOf(AName);'#013#010+
|
|
|
+ ' If (I<>-1) then'#013#010+
|
|
|
+ ' begin'#013#010+
|
|
|
+ ' FList.Objects[i].Free;'#013#010+
|
|
|
+ ' FList.Delete(I);'#013#010+
|
|
|
+ ' end;'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ #013#010+
|
|
|
+ 'function TDictionary.GetValue(AName: String): String;'#013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' Result:=GetValue(','AName,'#039#039');'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ #013#010+
|
|
|
+ 'function TDictionary.GetValue(const AName,Args: String): String;'#013#010+
|
|
|
+ 'Var'#013#010+
|
|
|
+ ' O : TObject;'#013#010+
|
|
|
+ ' I : Integer;'#013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' I:=Flist.IndexOf(AName);'#013#010+
|
|
|
+ ' If (I=-1) then'#013#010+
|
|
|
+ ' Raise EDictionaryError.CreateFmt(SErrNoDictionaryItem,[ANa','me]);'#013+
|
|
|
+ #010+
|
|
|
+ ' O:=Flist.Objects[I];'#013#010+
|
|
|
+ ' If O is TValueItem then'#013#010+
|
|
|
+ ' Result:=TValueItem(O).FValue'#013#010+
|
|
|
+ ' else'#013#010+
|
|
|
+ ' Result:=TFunctionItem(O).FFunc(AName,Args);'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ #013#010+
|
|
|
+ 'function TDictionary.ReplaceStrings(Const ASource: String): String;'#013+
|
|
|
+ #010+
|
|
|
+ 'Var'#013#010+
|
|
|
+ ' S,FN,','FV : String;'#013#010+
|
|
|
+ ' P: Integer;'#013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' Result:='#039#039';'#013#010+
|
|
|
+ ' S:=ASource;'#013#010+
|
|
|
+ ' P:=Pos('#039'$('#039',S);'#013#010+
|
|
|
+ ' While (P<>0) do'#013#010+
|
|
|
+ ' begin'#013#010+
|
|
|
+ ' Result:=Result+Copy(S,1,P-1);'#013#010+
|
|
|
+ ' Delete(S,1,P+1);'#013#010+
|
|
|
+ ' P:=Pos('#039')'#039',S);'#013#010+
|
|
|
+ ' FN:=Copy(S,1,P-1);'#013#010+
|
|
|
+ ' Delete(S,1',',P);'#013#010+
|
|
|
+ ' P:=Pos('#039' '#039',FN);'#013#010+
|
|
|
+ ' If (P<>0) then // function arguments ?'#013#010+
|
|
|
+ ' begin'#013#010+
|
|
|
+ ' FV:=FN;'#013#010+
|
|
|
+ ' FN:=Copy(FN,1,P);'#013#010+
|
|
|
+ ' System.Delete(FV,1,P);'#013#010+
|
|
|
+ ' end'#013#010+
|
|
|
+ ' else'#013#010+
|
|
|
+ ' FV:='#039#039';'#013#010+
|
|
|
+ ' Result:=Result+GetValue(FN',',FV);'#013#010+
|
|
|
+ ' P:=Pos('#039'$('#039',S);'#013#010+
|
|
|
+ ' end;'#013#010+
|
|
|
+ ' Result:=Result+S;'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ #013#010+
|
|
|
'Function TDictionary.Substitute(Const Source : String; Macros : Array '+
|
|
|
- 'of string) : String;'#010+
|
|
|
- 'Var'#010+
|
|
|
- ' I : Integer;'#010+
|
|
|
- 'begin'#010+
|
|
|
- ' I:=0;'#010+
|
|
|
- ' While I<High(Macros) do'#010+
|
|
|
- ' begin'#010+
|
|
|
- ' AddVariable(Macros[i],Ma','cros[I+1]);'#010+
|
|
|
- ' Inc(I,2);'#010+
|
|
|
- ' end;'#010+
|
|
|
- ' Result:=ReplaceStrings(Source);'#010+
|
|
|
- ' While I<High(Macros) do'#010+
|
|
|
- ' begin'#010+
|
|
|
- ' RemoveItem(Macros[i]);'#010+
|
|
|
- ' Inc(I,2);'#010+
|
|
|
- ' end;'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
- '{*********************************************************************'+
|
|
|
- '***','****'#010+
|
|
|
- ' Default Instances'#010+
|
|
|
+ 'of string) : String;'#013#010+
|
|
|
+ 'Var'#013#010+
|
|
|
+ ' I : Integer;'#013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' I:=0;'#013#010+
|
|
|
+ ' While I<High(Macros) do'#013#010+
|
|
|
+ ' begin'#013#010+
|
|
|
+ ' ',' AddVariable(Macros[i],Macros[I+1]);'#013#010+
|
|
|
+ ' Inc(I,2);'#013#010+
|
|
|
+ ' end;'#013#010+
|
|
|
+ ' Result:=ReplaceStrings(Source);'#013#010+
|
|
|
+ ' While I<High(Macros) do'#013#010+
|
|
|
+ ' begin'#013#010+
|
|
|
+ ' RemoveItem(Macros[i]);'#013#010+
|
|
|
+ ' Inc(I,2);'#013#010+
|
|
|
+ ' end;'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ '{*********************************','**********************************'+
|
|
|
+ '*********'#013#010+
|
|
|
+ ' Default Instances'#013#010+
|
|
|
'**********************************************************************'+
|
|
|
- '******}'#010+
|
|
|
- #010+
|
|
|
- 'var'#010+
|
|
|
- ' DefInstaller : TCustomInstaller;'#010+
|
|
|
- #010+
|
|
|
- 'Function Installer(InstallerClass: TInstallerClass): TCustomInsta','lle'+
|
|
|
- 'r;'#010+
|
|
|
- 'begin'#010+
|
|
|
- ' If Not Assigned(DefInstaller) then'#010+
|
|
|
- ' DefInstaller:=InstallerClass.Create(Nil);'#010+
|
|
|
- ' Result:=DefInstaller;'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
- #010+
|
|
|
- 'Function Installer: TCustomInstaller;'#010+
|
|
|
- 'begin'#010+
|
|
|
- ' Result := Installer(TFPCInstaller);'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
- #010+
|
|
|
- #010+
|
|
|
- '{ TCommand }'#010+
|
|
|
- #010+
|
|
|
- 'function T','Command.GetOptions: TStrings;'#010+
|
|
|
- 'begin'#010+
|
|
|
- ' If (FOptions=Nil) then'#010+
|
|
|
- ' FOptions:=TStringList.Create;'#010+
|
|
|
- ' Result:=FOptions;'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
- 'procedure TCommand.SetOptions(const Value: TStrings);'#010+
|
|
|
- 'begin'#010+
|
|
|
- ' If (Value=Nil) or (Value.Count=0) then'#010+
|
|
|
- ' FreeAndNil(FOp','tions)'#010+
|
|
|
- ' else'#010+
|
|
|
- ' Options.Assign(Value);'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
- 'destructor TCommand.Destroy;'#010+
|
|
|
- 'begin'#010+
|
|
|
- ' FreeAndNil(FOptions);'#010+
|
|
|
- ' inherited Destroy;'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
- 'function TCommand.HaveOptions: Boolean;'#010+
|
|
|
- 'begin'#010+
|
|
|
- ' Result:=(FOptions<>Nil);'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
- #010+
|
|
|
- 'function TCommand.CmdLineOp','tions: String;'#010+
|
|
|
- 'begin'#010+
|
|
|
- ' If HaveOptions then'#010+
|
|
|
- ' Result:=OptionListToString(Options);'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
- 'procedure TCommand.ParseOptions(S: String);'#010+
|
|
|
- #010+
|
|
|
- 'begin'#010+
|
|
|
- ' Options:=OptionsToStringList(S);'#010+
|
|
|
- 'end;'#010+
|
|
|
- #010+
|
|
|
- 'Initialization'#010+
|
|
|
- ' OnGetApplicationName:=@GetFPMakeName;'#010+
|
|
|
- ' C','ustomFpmakeCommandlineOptions:=nil;'#010+
|
|
|
- ' CustomFpMakeCommandlineValues:=nil;'#010+
|
|
|
- #010+
|
|
|
- 'Finalization'#010+
|
|
|
- ' FreeAndNil(CustomFpMakeCommandlineValues);'#010+
|
|
|
- ' FreeAndNil(CustomFpmakeCommandlineOptions);'#010+
|
|
|
- ' FreeAndNil(DefInstaller);'#010+
|
|
|
- ' FreeAndNil(GlobalDictionary);'#010+
|
|
|
- ' ',' FreeAndNil(Defaults);'#010+
|
|
|
- 'end.'#010
|
|
|
+ '******}'#013#010+
|
|
|
+ #013#010+
|
|
|
+ 'var'#013#010+
|
|
|
+ ' DefInstaller : TCustomInstaller;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ 'Function Installer(','InstallerClass: TInstallerClass): TCustomInstalle'+
|
|
|
+ 'r;'#013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' If Not Assigned(DefInstaller) then'#013#010+
|
|
|
+ ' DefInstaller:=InstallerClass.Create(Nil);'#013#010+
|
|
|
+ ' Result:=DefInstaller;'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ #013#010+
|
|
|
+ 'Function Installer: TCustomInstaller;'#013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' Result := In','staller(TFPCInstaller);'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ #013#010+
|
|
|
+ #013#010+
|
|
|
+ '{ TCommand }'#013#010+
|
|
|
+ #013#010+
|
|
|
+ 'function TCommand.GetOptions: TStrings;'#013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' If (FOptions=Nil) then'#013#010+
|
|
|
+ ' FOptions:=TStringList.Create;'#013#010+
|
|
|
+ ' Result:=FOptions;'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ 'procedure TCommand.SetOptions(const Value: TStrin','gs);'#013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' If (Value=Nil) or (Value.Count=0) then'#013#010+
|
|
|
+ ' FreeAndNil(FOptions)'#013#010+
|
|
|
+ ' else'#013#010+
|
|
|
+ ' Options.Assign(Value);'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ 'destructor TCommand.Destroy;'#013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' FreeAndNil(FOptions);'#013#010+
|
|
|
+ ' inherited Destroy;'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ 'function TCommand.HaveO','ptions: Boolean;'#013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' Result:=(FOptions<>Nil);'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ #013#010+
|
|
|
+ 'function TCommand.CmdLineOptions: String;'#013#010+
|
|
|
+ 'begin'#013#010+
|
|
|
+ ' If HaveOptions then'#013#010+
|
|
|
+ ' Result:=OptionListToString(Options);'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ 'procedure TCommand.ParseOptions(S: String);'#013#010+
|
|
|
+ #013#010+
|
|
|
+ 'begin'#013#010,
|
|
|
+ ' Options:=OptionsToStringList(S);'#013#010+
|
|
|
+ 'end;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ 'Initialization'#013#010+
|
|
|
+ ' OnGetApplicationName:=@GetFPMakeName;'#013#010+
|
|
|
+ ' CustomFpmakeCommandlineOptions:=nil;'#013#010+
|
|
|
+ ' CustomFpMakeCommandlineValues:=nil;'#013#010+
|
|
|
+ #013#010+
|
|
|
+ 'Finalization'#013#010+
|
|
|
+ ' FreeAndNil(CustomFpMakeCommandlineValues);',#013#010+
|
|
|
+ ' FreeAndNil(CustomFpmakeCommandlineOptions);'#013#010+
|
|
|
+ ' FreeAndNil(DefInstaller);'#013#010+
|
|
|
+ ' FreeAndNil(GlobalDictionary);'#013#010+
|
|
|
+ ' FreeAndNil(Defaults);'#013#010+
|
|
|
+ 'end.'#013#010
|
|
|
);
|