1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039104010411042104310441045104610471048104910501051105210531054105510561057105810591060106110621063106410651066106710681069107010711072107310741075107610771078107910801081108210831084108510861087108810891090109110921093109410951096109710981099110011011102110311041105110611071108110911101111111211131114111511161117111811191120112111221123112411251126112711281129113011311132113311341135113611371138113911401141114211431144114511461147114811491150115111521153115411551156115711581159116011611162116311641165116611671168116911701171117211731174117511761177117811791180118111821183118411851186118711881189119011911192119311941195119611971198119912001201120212031204120512061207120812091210121112121213121412151216121712181219122012211222122312241225122612271228122912301231123212331234123512361237123812391240124112421243124412451246124712481249125012511252125312541255125612571258125912601261126212631264126512661267126812691270127112721273127412751276127712781279128012811282128312841285128612871288128912901291129212931294129512961297129812991300130113021303130413051306130713081309131013111312131313141315131613171318131913201321132213231324132513261327132813291330133113321333133413351336133713381339 |
- {$ifdef Delphi}
- const fpcmakeini : array[0..125] of string[240]=(
- {$else Delphi}
- const fpcmakeini : array[0..125,1..240] of char=(
- {$endif Delphi}
- ';'#010+
- '; Templates used by fpcmake to create a Makefile from Makefile.fpc'#010+
- ';'#010+
- #010+
- '[osdetect]'#010+
- '#####################################################################'#010+
- '# Autodetect OS (Linux or Dos or Windows NT or OS/2)'#010+
- '# define inUnix when running under',' Unix like environment'#010+
- '# (Linux,FreeBSD,Cygwin)'#010+
- '# define inWinNT when running under WinNT'#010+
- '# define inOS2 when running under OS/2'#010+
- '# define inCygwin when running under Cygwin32'#010+
- '###################################################','#################'+
- '#'#010+
- #010+
- '# We need only / in the path also remove the current dir'#010+
- 'override PATH:=$(subst \,/,$(PATH))'#010+
- #010+
- '# Determine if we'#039've a unix searchpath using : by looking for a ;'#010+
- '# that normally doesn'#039't exists in path names.'#010+
- 'ifeq ($(findst','ring ;,$(PATH)),)'#010+
- 'inUnix=1'#010+
- 'SEARCHPATH:=$(filter-out .,$(subst :, ,$(PATH)))'#010+
- 'else'#010+
- 'SEARCHPATH:=$(subst ;, ,$(PATH))'#010+
- 'endif'#010+
- #010+
- '# Search for PWD and determine also if we are under linux'#010+
- 'PWD:=$(strip $(wildcard $(addsuffix /pwd.exe,$(SEARCHPATH))))',#010+
- 'ifeq ($(PWD),)'#010+
- 'PWD:=$(strip $(wildcard $(addsuffix /pwd,$(SEARCHPATH))))'#010+
- 'ifeq ($(PWD),)'#010+
- 'nopwd:'#010+
- ' @echo You need the GNU utils package to use this Makefile!'#010+
- ' @echo Get ftp://ftp.freepascal.org/pub/fpc/dist/go32v2/utilgo3'+
- '2.zip'#010+
- ' ',' @exit'#010+
- 'else'#010+
- 'PWD:=$(firstword $(PWD))'#010+
- 'SRCEXEEXT='#010+
- 'endif'#010+
- 'else'#010+
- 'PWD:=$(firstword $(PWD))'#010+
- 'SRCEXEEXT=.exe'#010+
- 'endif'#010+
- #010+
- '# Detect NT - NT sets OS to Windows_NT'#010+
- '# Detect OS/2 - OS/2 has OS2_SHELL defined'#010+
- 'ifndef inUnix'#010+
- 'ifeq ($(OS),Windows_NT)'#010+
- 'inWinNT=','1'#010+
- 'else'#010+
- 'ifdef OS2_SHELL'#010+
- 'inOS2=1'#010+
- 'endif'#010+
- 'endif'#010+
- 'else'#010+
- 'ifneq ($(findstring cygwin,$(MACHTYPE)),)'#010+
- 'inCygWin=1'#010+
- 'endif'#010+
- 'endif'#010+
- #010+
- '# The extension of batch files / scripts'#010+
- 'ifdef inUnix'#010+
- 'BATCHEXT=.sh'#010+
- 'else'#010+
- 'ifdef inOS2'#010+
- 'BATCHEXT=.cmd'#010+
- 'else'#010+
- 'BATCHEXT=.bat'#010+
- 'endif'#010+
- 'end','if'#010+
- #010+
- '# Path Separator, the subst trick is necessary for the \ that can'#039't'+
- ' exists'#010+
- '# at the end of a line'#010+
- 'ifdef inUnix'#010+
- 'PATHSEP=/'#010+
- 'else'#010+
- 'PATHSEP:=$(subst /,\,/)'#010+
- 'endif'#010+
- #010+
- '# Base dir'#010+
- 'ifdef PWD'#010+
- 'BASEDIR:=$(subst \,/,$(shell $(PWD)))'#010+
- '# For Cygwin we need',' to replace /cygdrive/c/ with c:/'#010+
- 'ifdef inCygWin'#010+
- 'ifneq ($(findstring /cygdrive/,$(BASEDIR)),)'#010+
- 'BASENODIR:=$(patsubst /cygdrive%,%,$(BASEDIR))'#010+
- 'BASEDRIVE:=$(firstword $(subst /, ,$(BASENODIR)))'#010+
- 'BASEDIR:=$(subst /cygdrive/$(BASEDRIVE)/,$(BASEDR','IVE):/,$(BASEDIR))'#010+
- 'endif'#010+
- 'endif'#010+
- 'else'#010+
- 'BASEDIR=.'#010+
- 'endif'#010+
- #010+
- '[fpcdetect]'#010+
- '#####################################################################'#010+
- '# FPC version/target Detection'#010+
- '#####################################################################'#010+
- #010+
- '# W','hat compiler to use ?'#010+
- 'ifndef FPC'#010+
- '# Compatibility with old makefiles'#010+
- 'ifdef PP'#010+
- 'FPC=$(PP)'#010+
- 'else'#010+
- 'ifdef inUnix'#010+
- 'CPU_SOURCE=$(shell uname -m)'#010+
- 'ifeq (m68k,$(CPU_SOURCE))'#010+
- 'FPC=ppc68k'#010+
- 'else'#010+
- 'FPC=ppc386'#010+
- 'endif'#010+
- 'else'#010+
- 'FPC=ppc386'#010+
- 'endif'#010+
- 'endif'#010+
- 'endif'#010+
- 'override FPC:','=$(subst $(SRCEXEEXT),,$(FPC))'#010+
- 'override FPC:=$(subst \,/,$(FPC))$(SRCEXEEXT)'#010+
- #010+
- '# Target OS'#010+
- 'ifndef OS_TARGET'#010+
- 'OS_TARGET:=$(shell $(FPC) -iTO)'#010+
- 'endif'#010+
- #010+
- '# Source OS'#010+
- 'ifndef OS_SOURCE'#010+
- 'OS_SOURCE:=$(shell $(FPC) -iSO)'#010+
- 'endif'#010+
- #010+
- '# Target CPU'#010+
- 'ifndef CPU_TA','RGET'#010+
- 'CPU_TARGET:=$(shell $(FPC) -iTP)'#010+
- 'endif'#010+
- #010+
- '# Source CPU'#010+
- 'ifndef CPU_SOURCE'#010+
- 'CPU_SOURCE:=$(shell $(FPC) -iSP)'#010+
- 'endif'#010+
- #010+
- '# FPC version'#010+
- 'ifndef FPC_VERSION'#010+
- 'FPC_VERSION:=$(shell $(FPC) -iV)'#010+
- 'endif'#010+
- #010+
- 'export FPC OS_TARGET OS_SOURCE CPU_TARGET CPU_SOURC','E FPC_VERSION'#010+
- #010+
- #010+
- '[fpcdircheckenv]'#010+
- '#####################################################################'#010+
- '# FPCDIR Setting'#010+
- '#####################################################################'#010+
- #010+
- '# Test FPCDIR to look if the RTL dir exists'#010+
- 'ifdef',' FPCDIR'#010+
- 'override FPCDIR:=$(subst \,/,$(FPCDIR))'#010+
- 'ifeq ($(wildcard $(addprefix $(FPCDIR)/,rtl units)),)'#010+
- 'override FPCDIR=wrong'#010+
- 'endif'#010+
- 'else'#010+
- 'override FPCDIR=wrong'#010+
- 'endif'#010+
- #010+
- #010+
- '[fpcdirdetect]'#010+
- '# Detect FPCDIR'#010+
- 'ifeq ($(FPCDIR),wrong)'#010+
- 'ifdef inUnix'#010+
- 'override',' FPCDIR=/usr/local/lib/fpc/$(FPC_VERSION)'#010+
- 'ifeq ($(wildcard $(FPCDIR)/units),)'#010+
- 'override FPCDIR=/usr/lib/fpc/$(FPC_VERSION)'#010+
- 'endif'#010+
- 'else'#010+
- 'override FPCDIR:=$(subst /$(FPC),,$(firstword $(strip $(wildcard $(add'+
- 'suffix /$(FPC),$(SEARCHPATH))))))'#010+
- 'ove','rride FPCDIR:=$(FPCDIR)/..'#010+
- 'ifeq ($(wildcard $(addprefix $(FPCDIR)/,rtl units)),)'#010+
- 'override FPCDIR:=$(FPCDIR)/..'#010+
- 'ifeq ($(wildcard $(addprefix $(FPCDIR)/,rtl units)),)'#010+
- 'override FPCDIR=c:/pp'#010+
- 'endif'#010+
- 'endif'#010+
- 'endif'#010+
- 'endif'#010+
- #010+
- '# Units dir'#010+
- 'UNITSDIR:=$(wild','card $(FPCDIR)/units/$(OS_TARGET))'#010+
- #010+
- '# Packages dir'#010+
- 'PACKAGESDIR:=$(wildcard $(FPCDIR) $(FPCDIR)/packages)'#010+
- #010+
- #010+
- '[shelltools]'#010+
- '#####################################################################'#010+
- '# Shell tools'#010+
- '####################################','################################'+
- '#'#010+
- #010+
- '# Echo that can redir (must be able run in the default OS shell)'#010+
- 'ifndef ECHOREDIR'#010+
- 'ECHOREDIR:=$(subst /,$(PATHSEP),$(ECHO))'#010+
- 'endif'#010+
- #010+
- '# To copy pograms'#010+
- 'ifndef COPY'#010+
- 'COPY:=$(CPPROG) -fp'#010+
- 'endif'#010+
- #010+
- '# Copy a whole tre','e'#010+
- 'ifndef COPYTREE'#010+
- 'COPYTREE:=$(CPPROG) -rfp'#010+
- 'endif'#010+
- #010+
- '# To move pograms'#010+
- 'ifndef MOVE'#010+
- 'MOVE:=$(MVPROG) -f'#010+
- 'endif'#010+
- #010+
- '# Check delete program'#010+
- 'ifndef DEL'#010+
- 'DEL:=$(RMPROG) -f'#010+
- 'endif'#010+
- #010+
- '# Check deltree program'#010+
- 'ifndef DELTREE'#010+
- 'DELTREE:=$(RMPROG) -rf'#010+
- 'endif'#010+
- #010+
- '# To i','nstall files'#010+
- 'ifndef INSTALL'#010+
- 'ifdef inUnix'#010+
- 'INSTALL:=$(GINSTALL) -c -m 644'#010+
- 'else'#010+
- 'INSTALL:=$(COPY)'#010+
- 'endif'#010+
- 'endif'#010+
- #010+
- '# To install programs'#010+
- 'ifndef INSTALLEXE'#010+
- 'ifdef inUnix'#010+
- 'INSTALLEXE:=$(GINSTALL) -c -m 755'#010+
- 'else'#010+
- 'INSTALLEXE:=$(COPY)'#010+
- 'endif'#010+
- 'endif'#010+
- #010+
- '# To mak','e a directory.'#010+
- 'ifndef MKDIR'#010+
- 'MKDIR:=$(GINSTALL) -m 755 -d'#010+
- 'endif'#010+
- #010+
- 'export ECHOREDIR COPY COPYTREE MOVE DEL DELTREE INSTALL INSTALLEXE MKD'+
- 'IR'#010+
- #010+
- #010+
- '[defaulttools]'#010+
- '#####################################################################'#010+
- '# Default Tools'#010,
- '#####################################################################'#010+
- #010+
- '# assembler, redefine it if cross compiling'#010+
- 'ifndef AS'#010+
- 'AS=as'#010+
- 'endif'#010+
- #010+
- '# linker, but probably not used'#010+
- 'ifndef LD'#010+
- 'LD=ld'#010+
- 'endif'#010+
- #010+
- '# Resource compiler'#010+
- 'ifndef RC'#010+
- 'RC=rc'#010+
- 'endif'#010+
- #010+
- '# pp','as.bat / ppas.sh'#010+
- 'PPAS=ppas$(BATCHEXT)'#010+
- #010+
- '# ldconfig to rebuild .so cache'#010+
- 'ifdef inUnix'#010+
- 'LDCONFIG=ldconfig'#010+
- 'else'#010+
- 'LDCONFIG='#010+
- 'endif'#010+
- #010+
- 'ifdef DATE'#010+
- 'DATESTR:=$(shell $(DATE) +%Y%m%d)'#010+
- 'else'#010+
- 'DATESTR='#010+
- 'endif'#010+
- #010+
- '# Look if UPX is found for go32v2 and win32. We ca','n'#039't use $UPX b'+
- 'ecuase'#010+
- '# upx uses that one itself (PFV)'#010+
- 'ifndef UPXPROG'#010+
- 'ifeq ($(OS_TARGET),go32v2)'#010+
- 'UPXPROG:=1'#010+
- 'endif'#010+
- 'ifeq ($(OS_TARGET),win32)'#010+
- 'UPXPROG:=1'#010+
- 'endif'#010+
- 'ifdef UPXPROG'#010+
- 'UPXPROG:=$(strip $(wildcard $(addsuffix /upx$(SRCEXEEXT),$(SEARCHPATH)',
- ')))'#010+
- 'ifeq ($(UPXPROG),)'#010+
- 'UPXPROG='#010+
- 'else'#010+
- 'UPXPROG:=$(firstword $(UPXPROG))'#010+
- 'endif'#010+
- 'else'#010+
- 'UPXPROG='#010+
- 'endif'#010+
- 'endif'#010+
- 'export UPXPROG'#010+
- #010+
- '# Zip options'#010+
- 'ZIPOPT=-9'#010+
- 'ZIPEXT=.zip'#010+
- #010+
- '# Tar options'#010+
- 'ifeq ($(USETAR),bz2)'#010+
- 'TAROPT=vI'#010+
- 'TAREXT=.tar.bz2'#010+
- 'else'#010+
- 'TAROPT=vz'#010+
- 'TAREXT=.t','ar.gz'#010+
- 'endif'#010+
- #010+
- #010+
- '[extensions]'#010+
- '#####################################################################'#010+
- '# Default extensions'#010+
- '#####################################################################'#010+
- #010+
- '# Default needed extensions (Go32v2,Linux)'#010+
- 'LOADEREX','T=.as'#010+
- 'EXEEXT=.exe'#010+
- 'PPLEXT=.ppl'#010+
- 'PPUEXT=.ppu'#010+
- 'OEXT=.o'#010+
- 'ASMEXT=.s'#010+
- 'SMARTEXT=.sl'#010+
- 'STATICLIBEXT=.a'#010+
- 'SHAREDLIBEXT=.so'#010+
- 'STATICLIBPREFIX=libp'#010+
- 'RSTEXT=.rst'#010+
- 'FPCMADE=fpcmade'#010+
- #010+
- #010+
- '# Go32v1'#010+
- 'ifeq ($(OS_TARGET),go32v1)'#010+
- 'PPUEXT=.pp1'#010+
- 'OEXT=.o1'#010+
- 'ASMEXT=.s1'#010+
- 'SMARTEXT=.sl1'#010+
- 'S','TATICLIBEXT=.a1'#010+
- 'SHAREDLIBEXT=.so1'#010+
- 'STATICLIBPREFIX='#010+
- 'FPCMADE=fpcmade.v1'#010+
- 'PACKAGESUFFIX=v1'#010+
- 'endif'#010+
- #010+
- '# Go32v2'#010+
- 'ifeq ($(OS_TARGET),go32v2)'#010+
- 'STATICLIBPREFIX='#010+
- 'FPCMADE=fpcmade.dos'#010+
- 'ZIPSUFFIX=go32'#010+
- 'endif'#010+
- #010+
- '# Linux'#010+
- 'ifeq ($(OS_TARGET),linux)'#010+
- 'EXEEXT='#010+
- 'HASSHARED','LIB=1'#010+
- 'FPCMADE=fpcmade.lnx'#010+
- 'ZIPSUFFIX=linux'#010+
- 'endif'#010+
- #010+
- '# Linux'#010+
- 'ifeq ($(OS_TARGET),freebsd)'#010+
- 'EXEEXT='#010+
- 'HASSHAREDLIB=1'#010+
- 'FPCMADE=fpcmade.freebsd'#010+
- 'ZIPSUFFIX=freebsd'#010+
- 'endif'#010+
- #010+
- '# Win32'#010+
- 'ifeq ($(OS_TARGET),win32)'#010+
- 'PPUEXT=.ppw'#010+
- 'OEXT=.ow'#010+
- 'ASMEXT=.sw'#010+
- 'SMARTEXT=.slw'#010+
- 'STA','TICLIBEXT=.aw'#010+
- 'SHAREDLIBEXT=.dll'#010+
- 'FPCMADE=fpcmade.w32'#010+
- 'ZIPSUFFIX=w32'#010+
- 'endif'#010+
- #010+
- '# OS/2'#010+
- 'ifeq ($(OS_TARGET),os2)'#010+
- 'PPUEXT=.ppo'#010+
- 'ASMEXT=.so2'#010+
- 'OEXT=.oo2'#010+
- 'AOUTEXT=.out'#010+
- 'SMARTEXT=.so'#010+
- 'STATICLIBEXT=.ao2'#010+
- 'SHAREDLIBEXT=.dll'#010+
- 'FPCMADE=fpcmade.os2'#010+
- 'ZIPSUFFIX=emx'#010+
- 'endif'#010,
- #010+
- '# Amiga'#010+
- 'ifeq ($(OS_TARGET),amiga)'#010+
- 'EXEEXT='#010+
- 'PPUEXT=.ppa'#010+
- 'ASMEXT=.asm'#010+
- 'OEXT=.o'#010+
- 'SMARTEXT=.sl'#010+
- 'STATICLIBEXT=.a'#010+
- 'SHAREDLIBEXT=.library'#010+
- 'FPCMADE=fpcmade.amg'#010+
- 'endif'#010+
- #010+
- '# Atari'#010+
- 'ifeq ($(OS_TARGET),atari)'#010+
- 'PPUEXT=.ppt'#010+
- 'ASMEXT=.s'#010+
- 'OEXT=.o'#010+
- 'SMARTEXT=.sl'#010+
- 'STATICLIBE','XT=.a'#010+
- 'EXEEXT=.ttp'#010+
- 'FPCMADE=fpcmade.ata'#010+
- 'endif'#010+
- #010+
- '[defaultdirs]'#010+
- '#####################################################################'#010+
- '# Default Directories'#010+
- '#####################################################################'#010+
- #010+
- '# Units dir'#010+
- 'ifdef ','REQUIRE_UNITSDIR'#010+
- 'override UNITSDIR+=$(REQUIRE_UNITSDIR)'#010+
- 'endif'#010+
- #010+
- '# Units dir'#010+
- 'ifdef REQUIRE_PACKAGESDIR'#010+
- 'override PACKAGESDIR+=$(REQUIRE_PACKAGESDIR)'#010+
- 'endif'#010+
- #010+
- #010+
- '# Linux and freebsd use unix dirs with /usr/bin, /usr/lib'#010+
- '# When zipping use the targe','t as default, when normal install then'#010+
- '# use the source os as default'#010+
- 'ifdef ZIPINSTALL'#010+
- '# Zipinstall'#010+
- 'ifeq ($(OS_TARGET),linux)'#010+
- 'UNIXINSTALLDIR=1'#010+
- 'endif'#010+
- 'ifeq ($(OS_TARGET),freebsd)'#010+
- 'UNIXINSTALLDIR=1'#010+
- 'endif'#010+
- 'else'#010+
- '# Normal install'#010+
- 'ifeq ($(OS_SOURCE)',',linux)'#010+
- 'UNIXINSTALLDIR=1'#010+
- 'endif'#010+
- 'ifeq ($(OS_SOURCE),freebsd)'#010+
- 'UNIXINSTALLDIR=1'#010+
- 'endif'#010+
- 'endif'#010+
- #010+
- '# set the prefix directory where to install everything'#010+
- 'ifndef INSTALL_PREFIX'#010+
- 'ifdef UNIXINSTALLDIR'#010+
- 'INSTALL_PREFIX=/usr/local'#010+
- 'else'#010+
- 'ifdef INSTALL_FPCPACKA','GE'#010+
- 'INSTALL_BASEDIR:=/pp'#010+
- 'else'#010+
- 'INSTALL_BASEDIR:=/$(PACKAGE_NAME)'#010+
- 'endif'#010+
- 'endif'#010+
- 'endif'#010+
- 'export INSTALL_PREFIX'#010+
- #010+
- '# Where to place the resulting zip files'#010+
- 'ifndef DIST_DESTDIR'#010+
- 'DIST_DESTDIR:=$(BASEDIR)'#010+
- 'endif'#010+
- 'export DIST_DESTDIR'#010+
- #010+
- #010+
- '######################','##############################################'+
- '#'#010+
- '# Install Directories'#010+
- '#####################################################################'#010+
- #010+
- '# set the base directory where to install everything'#010+
- 'ifndef INSTALL_BASEDIR'#010+
- 'ifdef UNIXINSTALLDIR'#010+
- 'if','def INSTALL_FPCPACKAGE'#010+
- 'INSTALL_BASEDIR:=$(INSTALL_PREFIX)/lib/fpc/$(FPC_VERSION)'#010+
- 'else'#010+
- 'INSTALL_BASEDIR:=$(INSTALL_PREFIX)/lib/$(PACKAGE_NAME)'#010+
- 'endif'#010+
- 'else'#010+
- 'INSTALL_BASEDIR:=$(INSTALL_PREFIX)'#010+
- 'endif'#010+
- 'endif'#010+
- #010+
- '# set the directory where to install the',' binaries'#010+
- 'ifndef INSTALL_BINDIR'#010+
- 'ifdef UNIXINSTALLDIR'#010+
- 'INSTALL_BINDIR:=$(INSTALL_PREFIX)/bin'#010+
- 'else'#010+
- 'INSTALL_BINDIR:=$(INSTALL_BASEDIR)/bin'#010+
- '# for FPC packages install the binaries under their os target subdir'#010+
- 'ifdef INSTALL_FPCPACKAGE'#010+
- 'INSTALL_BIN','DIR:=$(INSTALL_BINDIR)/$(OS_TARGET)'#010+
- 'endif'#010+
- 'endif'#010+
- 'endif'#010+
- #010+
- '# set the directory where to install the units.'#010+
- 'ifndef INSTALL_UNITDIR'#010+
- 'INSTALL_UNITDIR:=$(INSTALL_BASEDIR)/units/$(OS_TARGET)'#010+
- 'ifdef INSTALL_FPCPACKAGE'#010+
- 'ifdef PACKAGE_NAME'#010+
- 'INSTALL_UNITDIR',':=$(INSTALL_UNITDIR)/$(PACKAGE_NAME)'#010+
- 'endif'#010+
- 'endif'#010+
- 'endif'#010+
- #010+
- '# Where to install shared libraries'#010+
- 'ifndef INSTALL_LIBDIR'#010+
- 'ifdef UNIXINSTALLDIR'#010+
- 'INSTALL_LIBDIR:=$(INSTALL_PREFIX)/lib'#010+
- 'else'#010+
- 'INSTALL_LIBDIR:=$(INSTALL_UNITDIR)'#010+
- 'endif'#010+
- 'endif'#010+
- #010+
- '# Where the so','urce files will be stored'#010+
- 'ifndef INSTALL_SOURCEDIR'#010+
- 'ifdef UNIXINSTALLDIR'#010+
- 'ifdef INSTALL_FPCPACKAGE'#010+
- 'INSTALL_SOURCEDIR:=$(INSTALL_PREFIX)/src/fpc-$(FPC_VERSION)/$(PACKAGE_'+
- 'NAME)'#010+
- 'else'#010+
- 'INSTALL_SOURCEDIR:=$(INSTALL_PREFIX)/src/$(PACKAGE_NAME)-$(PAC','KAGE_V'+
- 'ERSION)'#010+
- 'endif'#010+
- 'else'#010+
- 'ifdef INSTALL_FPCPACKAGE'#010+
- 'INSTALL_SOURCEDIR:=$(INSTALL_BASEDIR)/source/$(PACKAGE_NAME)'#010+
- 'else'#010+
- 'INSTALL_SOURCEDIRL:=$(INSTALL_BASEDIR)/source'#010+
- 'endif'#010+
- 'endif'#010+
- 'endif'#010+
- #010+
- '# Where the doc files will be stored'#010+
- 'ifndef INSTALL_DOCDIR'#010,
- 'ifdef UNIXINSTALLDIR'#010+
- 'ifdef INSTALL_FPCPACKAGE'#010+
- 'INSTALL_DOCDIR:=$(INSTALL_PREFIX)/doc/fpc-$(FPC_VERSION)/$(PACKAGE_NAM'+
- 'E)'#010+
- 'else'#010+
- 'INSTALL_DOCDIR:=$(INSTALL_PREFIX)/doc/$(PACKAGE_NAME)-$(PACKAGE_VERSIO'+
- 'N)'#010+
- 'endif'#010+
- 'else'#010+
- 'ifdef INSTALL_FPCPACKAGE'#010+
- 'INSTALL','_DOCDIR:=$(INSTALL_BASEDIR)/doc/$(PACKAGE_NAME)'#010+
- 'else'#010+
- 'INSTALL_DOCDIR:=$(INSTALL_BASEDIR)/doc'#010+
- 'endif'#010+
- 'endif'#010+
- 'endif'#010+
- #010+
- '# Where to install the examples, under linux we use the doc dir'#010+
- '# because the copytree command will create a subdir itself'#010+
- 'ifndef',' INSTALL_EXAMPLEDIR'#010+
- 'ifdef UNIXINSTALLDIR'#010+
- 'ifdef INSTALL_FPCPACKAGE'#010+
- 'INSTALL_EXAMPLEDIR:=$(INSTALL_PREFIX)/doc/fpc-$(FPC_VERSION)/examples/'+
- '$(PACKAGE_NAME)'#010+
- 'else'#010+
- 'INSTALL_EXAMPLEDIR:=$(INSTALL_PREFIX)/doc/$(PACKAGE_NAME)-$(PACKAGE_VE'+
- 'RSION)'#010+
- 'endif'#010,
- 'else'#010+
- 'ifdef INSTALL_FPCPACKAGE'#010+
- 'INSTALL_EXAMPLEDIR:=$(INSTALL_BASEDIR)/examples/$(PACKAGE_NAME)'#010+
- 'else'#010+
- 'INSTALL_EXAMPLEDIR:=$(INSTALL_BASEDIR)/examples'#010+
- 'endif'#010+
- 'endif'#010+
- 'endif'#010+
- #010+
- '# Where the some extra (data)files will be stored'#010+
- 'ifndef INSTALL_DATADIR'#010+
- 'I','NSTALL_DATADIR=$(INSTALL_BASEDIR)'#010+
- 'endif'#010+
- #010+
- #010+
- '[dirlibc]'#010+
- '# On linux, try to find where libgcc.a is.'#010+
- 'ifdef inUnix'#010+
- 'ifndef GCCLIBDIR'#010+
- 'GCCLIBDIR:=$(shell dirname `(gcc -v 2>&1)| head -n 1| awk '#039'{ print'+
- ' $$4 } '#039'`)'#010+
- 'endif'#010+
- 'ifndef OTHERLIBDIR'#010+
- 'OTHERLIBDIR:=','$(shell grep -v "^\#" /etc/ld.so.conf | awk '#039'{ ORS='+
- '" "; print $1 }'#039')'#010+
- 'endif'#010+
- 'export GCCLIBDIR OTHERLIB'#010+
- 'endif'#010+
- #010+
- #010+
- '[command_begin]'#010+
- '#####################################################################'#010+
- '# Compiler Command Line'#010+
- '#####################','###############################################'+
- '#'#010+
- #010+
- '# Load commandline OPTDEF and add FPC_CPU define'#010+
- 'override FPCOPTDEF=$(CPU_TARGET)'#010+
- #010+
- '# Load commandline OPT and add target and unit dir to be sure'#010+
- 'ifneq ($(OS_TARGET),$(OS_SOURCE))'#010+
- 'override FP','COPT+=-T$(OS_TARGET)'#010+
- 'endif'#010+
- #010+
- '# User dirs should be first, so they are looked at first'#010+
- 'ifdef UNITDIR'#010+
- 'override FPCOPT+=$(addprefix -Fu,$(UNITDIR))'#010+
- 'endif'#010+
- 'ifdef LIBDIR'#010+
- 'override FPCOPT+=$(addprefix -Fl,$(LIBDIR))'#010+
- 'endif'#010+
- 'ifdef OBJDIR'#010+
- 'override FPCOP','T+=$(addprefix -Fo,$(OBJDIR))'#010+
- 'endif'#010+
- 'ifdef INCDIR'#010+
- 'override FPCOPT+=$(addprefix -Fi,$(INCDIR))'#010+
- 'endif'#010+
- #010+
- '# Smartlinking'#010+
- 'ifdef LINKSMART'#010+
- 'override FPCOPT+=-XX'#010+
- 'endif'#010+
- #010+
- '# Smartlinking creation'#010+
- 'ifdef CREATESMART'#010+
- 'override FPCOPT+=-CX'#010+
- 'endif'#010+
- #010+
- '# Debug'#010+
- 'ifd','ef DEBUG'#010+
- 'override FPCOPT+=-gl'#010+
- 'override FPCOPTDEF+=DEBUG'#010+
- 'endif'#010+
- #010+
- '# Release mode (strip, optimize and don'#039't load ppc386.cfg)'#010+
- 'ifdef RELEASE'#010+
- 'override FPCOPT+=-Xs -OG2p3 -n'#010+
- 'override FPCOPTDEF+=RELEASE'#010+
- 'endif'#010+
- #010+
- '# Strip'#010+
- 'ifdef STRIP'#010+
- 'override FPCOPT+=-','Xs'#010+
- 'endif'#010+
- #010+
- '# Optimizer'#010+
- 'ifdef OPTIMIZE'#010+
- 'override FPCOPT+=-OG2p3'#010+
- 'endif'#010+
- #010+
- '# Verbose settings (warning,note,info)'#010+
- 'ifdef VERBOSE'#010+
- 'override FPCOPT+=-vwni'#010+
- 'endif'#010+
- #010+
- '# Needed compiler options'#010+
- 'ifdef COMPILER_OPTIONS'#010+
- 'override FPCOPT+=$(COMPILER_OPTIONS)'#010+
- 'end','if'#010+
- 'ifdef COMPILER_UNITDIR'#010+
- 'override FPCOPT+=$(addprefix -Fu,$(COMPILER_UNITDIR))'#010+
- 'endif'#010+
- 'ifdef COMPILER_LIBRARYDIR'#010+
- 'override FPCOPT+=$(addprefix -Fl,$(COMPILER_LIBRARYDIR))'#010+
- 'endif'#010+
- 'ifdef COMPILER_OBJECTDIR'#010+
- 'override FPCOPT+=$(addprefix -Fo,$(COMPI','LER_OBJECTDIR))'#010+
- 'endif'#010+
- 'ifdef COMPILER_INCLUDEDIR'#010+
- 'override FPCOPT+=$(addprefix -Fi,$(COMPILER_INCLUDEDIR))'#010+
- 'endif'#010+
- #010+
- '# Target dirs and the prefix to use for clean/install'#010+
- 'ifdef COMPILER_TARGETDIR'#010+
- 'override FPCOPT+=-FE$(COMPILER_TARGETDIR)'#010+
- 'ifeq ($','(COMPILER_TARGETDIR),.)'#010+
- 'override TARGETDIRPREFIX='#010+
- 'else'#010+
- 'override TARGETDIRPREFIX=$(COMPILER_TARGETDIR)/'#010+
- 'endif'#010+
- 'endif'#010+
- #010+
- '# Unit target dir'#010+
- 'ifdef COMPILER_UNITTARGETDIR'#010+
- 'override FPCOPT+=-FU$(COMPILER_UNITTARGETDIR)'#010+
- 'ifeq ($(COMPILER_UNITTARGETDIR)',',.)'#010+
- 'override UNITTARGETDIRPREFIX='#010+
- 'else'#010+
- 'override UNITTARGETDIRPREFIX=$(COMPILER_TARGETDIR)/'#010+
- 'endif'#010+
- 'else'#010+
- 'ifdef COMPILER_TARGETDIR'#010+
- 'override COMPILER_UNITTARGETDIR=$(COMPILER_TARGETDIR)'#010+
- 'override UNITTARGETDIRPREFIX=$(TARGETDIRPREFIX)'#010+
- 'endif'#010+
- 'endif',#010+
- #010+
- '[command_libc]'#010+
- '# Add GCC lib path if asked'#010+
- 'ifdef GCCLIBDIR'#010+
- 'override FPCOPT+=-Fl$(GCCLIBDIR)'#010+
- 'endif'#010+
- 'ifdef OTHERLIBDIR'#010+
- 'override FPCOPT+=$(addprefix -Fl,$(OTHERLIBDIR))'#010+
- 'endif'#010+
- #010+
- #010+
- '[command_end]'#010+
- '# Add commandline options last so they can override',#010+
- 'ifdef OPT'#010+
- 'override FPCOPT+=$(OPT)'#010+
- 'endif'#010+
- #010+
- '# Add defines from FPCOPTDEF to FPCOPT'#010+
- 'ifdef FPCOPTDEF'#010+
- 'override FPCOPT+=$(addprefix -d,$(FPCOPTDEF))'#010+
- 'endif'#010+
- #010+
- '# Was a config file specified ?'#010+
- 'ifdef CFGFILE'#010+
- 'override FPCOPT+=@$(CFGFILE)'#010+
- 'endif'#010+
- #010+
- '# Use th','e environment to pass commandline options?'#010+
- 'ifdef USEENV'#010+
- 'override FPCEXTCMD:=$(FPCOPT)'#010+
- 'override FPCOPT:=!FPCEXTCMD'#010+
- 'export FPCEXTCMD'#010+
- 'endif'#010+
- #010+
- '# Compiler commandline'#010+
- 'override COMPILER:=$(FPC) $(FPCOPT)'#010+
- #010+
- '# also call ppas if with command option -s',#010+
- '# but only if the OS_SOURCE and OS_TARGET are equal'#010+
- 'ifeq (,$(findstring -s ,$(COMPILER)))'#010+
- 'EXECPPAS='#010+
- 'else'#010+
- 'ifeq ($(OS_SOURCE),$(OS_TARGET))'#010+
- 'EXECPPAS:=@$(PPAS)'#010+
- 'endif'#010+
- 'endif'#010+
- #010+
- #010+
- '[loaderrules]'#010+
- '######################################################','##############'+
- '#'#010+
- '# Loaders'#010+
- '#####################################################################'#010+
- #010+
- '.PHONY: fpc_loaders'#010+
- #010+
- 'ifdef TARGET_LOADERS'#010+
- 'override ALLTARGET+=fpc_loaders'#010+
- 'override CLEANTARGET+=fpc_loaders_clean'#010+
- 'override INSTALLTARGET+=fpc_l','oaders_install'#010+
- #010+
- 'override LOADEROFILES:=$(addsuffix $(OEXT),$(TARGET_LOADERS))'#010+
- 'endif'#010+
- #010+
- '%$(OEXT): %$(LOADEREXT)'#010+
- ' $(AS) -o $*$(OEXT) $<'#010+
- #010+
- 'fpc_loaders: $(LOADEROFILES)'#010+
- #010+
- 'fpc_loaders_clean:'#010+
- ' -$(DEL) $(LOADEROFILES)'#010+
- #010+
- 'fpc_loaders_instal','l:'#010+
- ' $(MKDIR) $(INSTALL_UNITDIR)'#010+
- ' $(INSTALL) $(LOADEROFILES) $(INSTALL_UNITDIR)'#010+
- #010+
- #010+
- '[unitrules]'#010+
- '#####################################################################'#010+
- '# Units'#010+
- '#######################################################','#############'+
- '#'#010+
- #010+
- '.PHONY: fpc_units'#010+
- #010+
- 'ifdef TARGET_UNITS'#010+
- 'override ALLTARGET+=fpc_units'#010+
- #010+
- 'override UNITPPUFILES=$(addsuffix $(PPUEXT),$(TARGET_UNITS))'#010+
- 'override INSTALLPPUFILES+=$(UNITPPUFILES)'#010+
- 'override CLEANPPUFILES+=$(UNITPPUFILES)'#010+
- 'endif'#010+
- #010+
- 'fpc_u','nits: $(UNITPPUFILES)'#010+
- #010+
- #010+
- '[exerules]'#010+
- '#####################################################################'#010+
- '# Exes'#010+
- '#####################################################################'#010+
- #010+
- '.PHONY: fpc_exes'#010+
- #010+
- 'ifdef TARGET_PROGRAMS'#010+
- 'override EXEFILES','=$(addsuffix $(EXEEXT),$(TARGET_PROGRAMS))'#010+
- 'override EXEOFILES:=$(addsuffix $(OEXT),$(TARGET_PROGRAMS)) $(addprefi'+
- 'x $(STATICLIBPREFIX),$(addsuffix $(STATICLIBEXT),$(TARGET_PROGRAMS)))'#010+
- #010+
- 'override ALLTARGET+=fpc_exes'#010+
- 'override INSTALLEXEFILES+=$','(EXEFILES)'#010+
- 'override CLEANEXEFILES+=$(EXEFILES) $(EXEOFILES)'#010+
- 'ifeq ($(OS_TARGET),os2)'#010+
- 'override CLEANEXEFILES+=$(addsuffix $(AOUTEXT),$(TARGET_PROGRAMS))'#010+
- 'endif'#010+
- 'endif'#010+
- #010+
- 'fpc_exes: $(EXEFILES)'#010+
- #010+
- #010+
- '[rstrules]'#010+
- '#########################################','###########################'+
- '#'#010+
- '# Resource strings'#010+
- '#####################################################################'#010+
- #010+
- 'ifdef TARGET_RSTS'#010+
- 'override RSTFILES=$(addsuffix $(RSTEXT),$(TARGET_RSTS))'#010+
- #010+
- 'override CLEANRSTFILES+=$(RSTFILES)'#010+
- 'endif'#010+
- #010+
- #010+
- '[e','xamplerules]'#010+
- '#####################################################################'#010+
- '# Examples'#010+
- '#####################################################################'#010+
- #010+
- '.PHONY: fpc_examples'#010+
- #010+
- 'ifdef TARGET_EXAMPLES'#010+
- 'HASEXAMPLES=1'#010+
- 'override EXAMPLES','OURCEFILES:=$(wildcard $(addsuffix .pp,$(TARGET_EXA'+
- 'MPLES)) $(addsuffix .pas,$(TARGET_EXAMPLES)))'#010+
- 'override EXAMPLEFILES:=$(addsuffix $(EXEEXT),$(TARGET_EXAMPLES))'#010+
- 'override EXAMPLEOFILES:=$(addsuffix $(OEXT),$(TARGET_EXAMPLES)) $(addp'+
- 'refix $(','STATICLIBPREFIX),$(addsuffix $(STATICLIBEXT),$(TARGET_EXAMPL'+
- 'ES)))'#010+
- #010+
- 'override CLEANEXEFILES+=$(EXAMPLEFILES) $(EXAMPLEOFILES)'#010+
- 'ifeq ($(OS_TARGET),os2)'#010+
- 'override CLEANEXEFILES+=$(addsuffix $(AOUTEXT),$(TARGET_EXAMPLES))'#010+
- 'endif'#010+
- 'endif'#010+
- 'ifdef TARGET_','EXAMPLEDIRS'#010+
- 'HASEXAMPLES=1'#010+
- 'endif'#010+
- #010+
- 'fpc_examples: all $(EXAMPLEFILES) $(addsuffix _all,$(TARGET_EXAMPLEDIR'+
- 'S))'#010+
- #010+
- #010+
- '[compilerules]'#010+
- '#####################################################################'#010+
- '# General compile rules'#010+
- '######################','##############################################'+
- '#'#010+
- #010+
- '.PHONY: fpc_packages fpc_all fpc_smart fpc_debug'#010+
- #010+
- '$(FPCMADE): $(ALLTARGET)'#010+
- ' @$(ECHOREDIR) Compiled > $(FPCMADE)'#010+
- #010+
- 'fpc_packages: $(COMPILEPACKAGES)'#010+
- #010+
- 'fpc_all: fpc_packages $(FPCMADE)'#010+
- #010+
- 'fpc','_smart:'#010+
- ' $(MAKE) all LINKSMART=1 CREATESMART=1'#010+
- #010+
- 'fpc_debug:'#010+
- ' $(MAKE) all DEBUG=1'#010+
- #010+
- '# General compile rules, available for both possible .pp and .pas exte'+
- 'nsions'#010+
- #010+
- '.SUFFIXES: $(EXEEXT) $(PPUEXT) $(OEXT) .pas .pp'#010+
- #010+
- '%$(PPUEXT): %.pp'#010+
- ' ',' $(COMPILER) $<'#010+
- ' $(EXECPPAS)'#010+
- #010+
- '%$(PPUEXT): %.pas'#010+
- ' $(COMPILER) $<'#010+
- ' $(EXECPPAS)'#010+
- #010+
- '%$(EXEEXT): %.pp'#010+
- ' $(COMPILER) $<'#010+
- ' $(EXECPPAS)'#010+
- #010+
- '%$(EXEEXT): %.pas'#010+
- ' $(COMPILER) $<'#010+
- ' $(EXECPPAS)'#010+
- #010+
- '# Search pat','hs for .ppu and .pp and .pas'#010+
- 'vpath %.pp $(COMPILER_SOURCEDIR) $(COMPILER_INCLUDEDIR)'#010+
- 'vpath %.pas $(COMPILER_SOURCEDIR) $(COMPILER_INCLUDEDIR)'#010+
- 'vpath %$(PPUEXT) $(COMPILER_UNITTARGETDIR)'#010+
- #010+
- #010+
- '[libraryrules]'#010+
- '######################################','##############################'+
- '#'#010+
- '# Library'#010+
- '#####################################################################'#010+
- #010+
- '.PHONY: fpc_shared'#010+
- #010+
- 'ifndef LIB_FULLNAME'#010+
- 'ifdef LIB_VERSION'#010+
- 'LIB_FULLNAME=$(LIB_NAME).$(LIB_VERSION)'#010+
- 'else'#010+
- 'LIB_FULLNAME=$(LIB_NAME)',#010+
- 'endif'#010+
- 'endif'#010+
- #010+
- '# Default sharedlib units are all unit objects'#010+
- 'ifndef LIB_SHAREDUNITS'#010+
- 'LIB_SHAREDUNITS:=$(TARGET_UNITS)'#010+
- 'endif'#010+
- #010+
- 'fpc_shared: all'#010+
- 'ifdef HASSHAREDLIB'#010+
- ' $(PPUMOVE) $(LIB_SHAREDUNITS) -o$(LIB_FULLNAME)'#010+
- 'else'#010+
- ' @$(ECHO) Sha','red Libraries not supported'#010+
- 'endif'#010+
- #010+
- #010+
- '[installrules]'#010+
- '#####################################################################'#010+
- '# Install rules'#010+
- '#####################################################################'#010+
- #010+
- '.PHONY: fpc_packagefpc fpc_insta','ll fpc_sourceinstall fpc_exampleinst'+
- 'all'#010+
- #010+
- 'ifdef INSTALL_UNITS'#010+
- 'override INSTALLPPUFILES+=$(addsuffix $(PPUEXT),$(INSTALL_UNITS))'#010+
- 'endif'#010+
- #010+
- 'ifdef INSTALLPPUFILES'#010+
- 'override INSTALLPPULINKFILES:=$(subst $(PPUEXT),$(OEXT),$(INSTALLPPUFI'+
- 'LES)) $(addpre','fix $(STATICLIBPREFIX),$(subst $(PPUEXT),$(STATICLIBEX'+
- 'T),$(INSTALLPPUFILES)))'#010+
- 'override INSTALLPPUFILES:=$(addprefix $(UNITTARGETDIRPREFIX),$(INSTALL'+
- 'PPUFILES))'#010+
- 'override INSTALLPPULINKFILES:=$(wildcard $(addprefix $(UNITTARGETDIRPR'+
- 'EFIX),$(INS','TALLPPULINKFILES)))'#010+
- 'endif'#010+
- #010+
- 'ifdef INSTALLEXEFILES'#010+
- 'override INSTALLEXEFILES:=$(addprefix $(TARGETDIRPREFIX),$(INSTALLEXEF'+
- 'ILES))'#010+
- 'endif'#010+
- #010+
- 'fpc_install: $(INSTALLTARGET)'#010+
- '# Create UnitInstallFiles'#010+
- 'ifdef INSTALLEXEFILES'#010+
- ' $(MKDIR) $(INSTALL_BI','NDIR)'#010+
- '# Compress the exes if upx is defined'#010+
- 'ifdef UPXPROG'#010+
- ' -$(UPXPROG) $(INSTALLEXEFILES)'#010+
- 'endif'#010+
- ' $(INSTALLEXE) $(INSTALLEXEFILES) $(INSTALL_BINDIR)'#010+
- 'endif'#010+
- 'ifdef INSTALLPPUFILES'#010+
- ' $(MKDIR) $(INSTALL_UNITDIR)'#010+
- '# If the packa','ge version is also set then we are the main package'#010+
- '# and we also need to install Package.fpc'#010+
- 'ifdef PACKAGE_VERSION'#010+
- ' $(FPCMAKE) -p Makefile.fpc'#010+
- ' $(INSTALL) Package.fpc $(INSTALL_UNITDIR)'#010+
- 'endif'#010+
- ' $(INSTALL) $(INSTALLPPUFI','LES) $(INSTALL_UNITDIR)'#010+
- 'ifneq ($(INSTALLPPULINKFILES),)'#010+
- ' $(INSTALL) $(INSTALLPPULINKFILES) $(INSTALL_UNITDIR)'#010+
- 'endif'#010+
- 'ifneq ($(wildcard $(LIB_FULLNAME)),)'#010+
- ' $(MKDIR) $(INSTALL_LIBDIR)'#010+
- ' $(INSTALL) $(LIB_FULLNAME) $(INSTALL_','LIBDIR)'#010+
- 'ifdef inUnix'#010+
- ' ln -sf $(LIB_FULLNAME) $(INSTALL_LIBDIR)/$(LIB_NAME)'#010+
- 'endif'#010+
- 'endif'#010+
- 'endif'#010+
- 'ifdef INSTALL_FILES'#010+
- ' $(MKDIR) $(INSTALL_DATADIR)'#010+
- ' $(INSTALL) $(INSTALL_FILES) $(INSTALL_DATADIR)'#010+
- 'endif'#010+
- #010+
- 'fpc_sourceinstall: dis','tclean'#010+
- ' $(MKDIR) $(INSTALL_SOURCEDIR)'#010+
- ' $(COPYTREE) $(BASEDIR) $(INSTALL_SOURCEDIR)'#010+
- #010+
- 'fpc_exampleinstall: $(addsuffix _distclean,$(TARGET_EXAMPLEDIRS))'#010+
- 'ifdef HASEXAMPLES'#010+
- ' $(MKDIR) $(INSTALL_EXAMPLEDIR)'#010+
- 'endif'#010+
- 'ifdef EXAMPLE','SOURCEFILES'#010+
- ' $(COPY) $(EXAMPLESOURCEFILES) $(INSTALL_EXAMPLEDIR)'#010+
- 'endif'#010+
- 'ifdef TARGET_EXAMPLEDIRS'#010+
- ' $(COPYTREE) $(addsuffix /*,$(TARGET_EXAMPLEDIRS)) $(INSTALL_EX'+
- 'AMPLEDIR)'#010+
- 'endif'#010+
- #010+
- '[distinstallrules]'#010+
- '###############################','#####################################'+
- '#'#010+
- '# Dist Install'#010+
- '#####################################################################'#010+
- #010+
- '.PHONY: fpc_distinstall'#010+
- #010+
- 'fpc_distinstall: install exampleinstall'#010+
- #010+
- #010+
- '[zipinstallrules]'#010+
- '##############################','######################################'+
- '#'#010+
- '# Zip'#010+
- '#####################################################################'#010+
- #010+
- '.PHONY: fpc_zipinstall fpc_zipsourceinstall fpc_zipexampleinstall'#010+
- #010+
- '# Temporary path to pack a file, can only use a single d','eep'#010+
- '# subdir, because the deltree can'#039't see the whole tree to remove'#010+
- 'ifndef PACKDIR'#010+
- 'ifndef inUnix'#010+
- 'PACKDIR=$(BASEDIR)/../fpc-pack'#010+
- 'else'#010+
- 'PACKDIR=/tmp/fpc-pack'#010+
- 'endif'#010+
- 'endif'#010+
- #010+
- '# Maybe create default zipname from packagename'#010+
- 'ifndef ZIPNAME'#010+
- 'ifdef DI','ST_ZIPNAME'#010+
- 'ZIPNAME=$(DIST_ZIPNAME)'#010+
- 'else'#010+
- 'ZIPNAME=$(ZIPPREFIX)$(PACKAGE_NAME)$(ZIPSUFFIX)'#010+
- 'endif'#010+
- 'endif'#010+
- #010+
- '# ZipTarget'#010+
- 'ifndef ZIPTARGET'#010+
- 'ifdef DIST_ZIPTARGET'#010+
- 'ZIPTARGET=DIST_ZIPTARGET'#010+
- 'else'#010+
- 'ZIPTARGET=install'#010+
- 'endif'#010+
- 'endif'#010+
- #010+
- '# Use tar by default under l','inux'#010+
- 'ifndef USEZIP'#010+
- 'ifdef inUnix'#010+
- 'USETAR=1'#010+
- 'endif'#010+
- 'endif'#010+
- #010+
- '# Use a wrapper script by default for Os/2'#010+
- 'ifndef inUnix'#010+
- 'USEZIPWRAPPER=1'#010+
- 'endif'#010+
- #010+
- '# We need to be able to run in the current OS so fix'#010+
- '# the path separator'#010+
- 'ifdef USEZIPWRAPPER'#010+
- 'ZIPPATHSEP=$','(PATHSEP)'#010+
- 'ZIPWRAPPER=$(subst /,$(PATHSEP),$(DIST_DESTDIR)/fpczip$(BATCHEXT))'#010+
- 'else'#010+
- 'ZIPPATHSEP=/'#010+
- 'endif'#010+
- #010+
- '# Create commands to create the zip/tar file'#010+
- 'ZIPCMD_CDPACK:=cd $(subst /,$(ZIPPATHSEP),$(PACKDIR))'#010+
- 'ZIPCMD_CDBASE:=cd $(subst /,$(ZIPPATHSE','P),$(BASEDIR))'#010+
- 'ifdef USETAR'#010+
- 'ZIPDESTFILE:=$(DIST_DESTDIR)/$(ZIPNAME)$(TAREXT)'#010+
- 'ZIPCMD_ZIP:=$(TARPROG) cf$(TAROPT) $(ZIPDESTFILE) *'#010+
- 'else'#010+
- 'ZIPDESTFILE:=$(DIST_DESTDIR)/$(ZIPNAME)$(ZIPEXT)'#010+
- 'ZIPCMD_ZIP:=$(subst /,$(ZIPPATHSEP),$(ZIPPROG)) -Dr $(ZIP','OPT) $(ZIPD'+
- 'ESTFILE) *'#010+
- 'endif'#010+
- #010+
- 'fpc_zipinstall:'#010+
- ' $(MAKE) $(ZIPTARGET) INSTALL_PREFIX=$(PACKDIR) ZIPINSTALL=1'#010+
- ' $(DEL) $(ZIPDESTFILE)'#010+
- 'ifdef USEZIPWRAPPER'#010+
- '# Handle gecho separate as we need to espace \ with \\'#010+
- 'ifneq ($(ECHOREDIR),ec','ho)'#010+
- ' $(ECHOREDIR) -e "$(subst \,\\,$(ZIPCMD_CDPACK))" > $(ZIPWRAPPE'+
- 'R)'#010+
- ' $(ECHOREDIR) -e "$(subst \,\\,$(ZIPCMD_ZIP))" >> $(ZIPWRAPPER)'+
- #010+
- ' $(ECHOREDIR) -e "$(subst \,\\,$(ZIPCMD_CDBASE))" >> $(ZIPWRAPP'+
- 'ER)'#010+
- 'else'#010+
- ' echo ','$(ZIPCMD_CDPACK) > $(ZIPWRAPPER)'#010+
- ' echo $(ZIPCMD_ZIP) >> $(ZIPWRAPPER)'#010+
- ' echo $(ZIPCMD_CDBASE) >> $(ZIPWRAPPER)'#010+
- 'endif'#010+
- 'ifdef inUnix'#010+
- ' /bin/sh $(ZIPWRAPPER)'#010+
- 'else'#010+
- ' $(ZIPWRAPPER)'#010+
- 'endif'#010+
- ' $(DEL) $(ZIPWRAPPER)'#010+
- 'else'#010,
- ' $(ZIPCMD_CDPACK) ; $(ZIPCMD_ZIP) ; $(ZIPCMD_CDBASE)'#010+
- 'endif'#010+
- ' $(DELTREE) $(PACKDIR)'#010+
- #010+
- 'fpc_zipsourceinstall:'#010+
- ' $(MAKE) fpc_zipinstall ZIPTARGET=sourceinstall ZIPSUFFIX=src'#010+
- #010+
- 'fpc_zipexampleinstall:'#010+
- 'ifdef HASEXAMPLES'#010+
- ' $(','MAKE) fpc_zipinstall ZIPTARGET=exampleinstall ZIPSUFFIX=ex'+
- 'm'#010+
- 'endif'#010+
- #010+
- 'fpc_zipdistinstall:'#010+
- ' $(MAKE) fpc_zipinstall ZIPTARGET=distinstall'#010+
- #010+
- #010+
- '[cleanrules]'#010+
- '#####################################################################'#010+
- '# Clean rules'#010+
- '#','###################################################################'+
- '#'#010+
- #010+
- '.PHONY: fpc_clean fpc_cleanall fpc_distclean'#010+
- #010+
- 'ifdef EXEFILES'#010+
- 'override CLEANEXEFILES:=$(addprefix $(TARGETDIRPREFIX),$(CLEANEXEFILES'+
- '))'#010+
- 'endif'#010+
- #010+
- 'ifdef CLEAN_UNITS'#010+
- 'override CL','EANPPUFILES+=$(addsuffix $(PPUEXT),$(CLEAN_UNITS))'#010+
- 'endif'#010+
- #010+
- 'ifdef CLEANPPUFILES'#010+
- 'override CLEANPPULINKFILES:=$(subst $(PPUEXT),$(OEXT),$(CLEANPPUFILES)'+
- ') $(addprefix $(STATICLIBPREFIX),$(subst $(PPUEXT),$(STATICLIBEXT),$(C'+
- 'LEANPPUFILES)))'#010+
- 'overri','de CLEANPPUFILES:=$(addprefix $(UNITTARGETDIRPREFIX),$(CLEANPP'+
- 'UFILES))'#010+
- 'override CLEANPPULINKFILES:=$(wildcard $(addprefix $(UNITTARGETDIRPREF'+
- 'IX),$(CLEANPPULINKFILES)))'#010+
- 'endif'#010+
- #010+
- 'fpc_clean: $(CLEANTARGET)'#010+
- 'ifdef CLEANEXEFILES'#010+
- ' -$(DEL) $(C','LEANEXEFILES)'#010+
- 'endif'#010+
- 'ifdef CLEANPPUFILES'#010+
- ' -$(DEL) $(CLEANPPUFILES)'#010+
- 'endif'#010+
- 'ifneq ($(CLEANPPULINKFILES),)'#010+
- ' -$(DEL) $(CLEANPPULINKFILES)'#010+
- 'endif'#010+
- 'ifdef CLEANRSTFILES'#010+
- ' -$(DEL) $(addprefix $(UNITTARGETDIRPREFIX),$(CLEANRSTFILES))',#010+
- 'endif'#010+
- 'ifdef CLEAN_FILES'#010+
- ' -$(DEL) $(CLEAN_FILES)'#010+
- 'endif'#010+
- 'ifdef LIB_NAME'#010+
- ' -$(DEL) $(LIB_NAME) $(LIB_FULLNAME)'#010+
- 'endif'#010+
- ' -$(DEL) $(FPCMADE) Package.fpc $(PPAS) link.res $(FPCEXTFILE) '+
- '$(REDIRFILE)'#010+
- #010+
- 'fpc_distclean: clean'#010+
- #010+
- '# Also ','run clean first if targetdir is set. Unittargetdir is always'#010+
- '# set if targetdir or unittargetdir is specified'#010+
- 'ifdef COMPILER_UNITTARGETDIR'#010+
- 'TARGETDIRCLEAN=fpc_clean'#010+
- 'endif'#010+
- #010+
- 'fpc_cleanall: $(CLEANTARGET) $(TARGETDIRCLEAN)'#010+
- 'ifdef CLEANEXEFILES'#010+
- ' ',' -$(DEL) $(CLEANEXEFILES)'#010+
- 'endif'#010+
- ' -$(DEL) *$(OEXT) *$(PPUEXT) *$(RSTEXT) *$(ASMEXT) *$(STATICLIB'+
- 'EXT) *$(SHAREDLIBEXT) *$(PPLEXT)'#010+
- ' -$(DELTREE) *$(SMARTEXT)'#010+
- ' -$(DEL) $(FPCMADE) $(PPAS) link.res $(FPCEXTFILE) $(REDIRFI','L'+
- 'E)'#010+
- 'ifdef AOUTEXT'#010+
- ' -$(DEL) *$(AOUTEXT)'#010+
- 'endif'#010+
- #010+
- #010+
- '[inforules]'#010+
- '#####################################################################'#010+
- '# Info rules'#010+
- '#####################################################################'#010+
- #010+
- '.PHONY: fpc_info'#010+
- #010+
- 'fp','c_info:'#010+
- ' @$(ECHO)'#010+
- ' @$(ECHO) == Package info =='#010+
- ' @$(ECHO) Package Name..... $(PACKAGE_NAME)'#010+
- ' @$(ECHO) Package Version.. $(PACKAGE_VERSION)'#010+
- ' @$(ECHO)'#010+
- ' @$(ECHO) == Configuration info =='#010+
- ' @$(','ECHO)'#010+
- ' @$(ECHO) FPC.......... $(FPC)'#010+
- ' @$(ECHO) FPC Version.. $(FPC_VERSION)'#010+
- ' @$(ECHO) Source CPU... $(CPU_SOURCE)'#010+
- ' @$(ECHO) Target CPU... $(CPU_TARGET)'#010+
- ' @$(ECHO) Source OS.... $(OS_SOURCE)'#010+
- ' @$(','ECHO) Target OS.... $(OS_TARGET)'#010+
- ' @$(ECHO)'#010+
- ' @$(ECHO) == Directory info =='#010+
- ' @$(ECHO)'#010+
- ' @$(ECHO) Basedir......... $(BASEDIR)'#010+
- ' @$(ECHO) FPCDir.......... $(FPCDIR)'#010+
- ' @$(ECHO) UnitsDir........ $(UNITS','DIR)'#010+
- ' @$(ECHO) PackagesDir..... $(PACKAGESDIR)'#010+
- ' @$(ECHO)'#010+
- ' @$(ECHO) GCC library..... $(GCCLIBDIR)'#010+
- ' @$(ECHO) Other library... $(OTHERLIBDIR)'#010+
- ' @$(ECHO)'#010+
- ' @$(ECHO) == Tools info =='#010+
- ' @$(ECHO)'#010+
- ' ',' @$(ECHO) Pwd....... $(PWD)'#010+
- ' @$(ECHO) Mv........ $(MVPROG)'#010+
- ' @$(ECHO) Cp........ $(CPPROG)'#010+
- ' @$(ECHO) Rm........ $(RMPROG)'#010+
- ' @$(ECHO) GInstall.. $(GINSTALL)'#010+
- ' @$(ECHO) Echo...... $(ECHO)'#010+
- ' @$','(ECHO) Date...... $(DATE)'#010+
- ' @$(ECHO) FPCMake... $(FPCMAKE)'#010+
- ' @$(ECHO) PPUMove... $(PPUMOVE)'#010+
- ' @$(ECHO) Upx....... $(UPXPROG)'#010+
- ' @$(ECHO) Zip....... $(ZIPPROG)'#010+
- ' @$(ECHO)'#010+
- ' @$(ECHO) == Object info =='#010,
- ' @$(ECHO)'#010+
- ' @$(ECHO) Target Loaders...... $(TARGET_LOADERS)'#010+
- ' @$(ECHO) Target Units........ $(TARGET_UNITS)'#010+
- ' @$(ECHO) Target Programs..... $(TARGET_PROGRAMS)'#010+
- ' @$(ECHO) Target Dirs......... $(TARGET_DIRS)',#010+
- ' @$(ECHO) Target Examples..... $(TARGET_EXAMPLES)'#010+
- ' @$(ECHO) Target ExampleDirs.. $(TARGET_EXAMPLEDIRS)'#010+
- ' @$(ECHO)'#010+
- ' @$(ECHO) Clean Units......... $(CLEAN_UNITS)'#010+
- ' @$(ECHO) Clean Files......... $(CLEAN_FI','LES)'#010+
- ' @$(ECHO)'#010+
- ' @$(ECHO) Install Units....... $(INSTALL_UNITS)'#010+
- ' @$(ECHO) Install Files....... $(INSTALL_FILES)'#010+
- ' @$(ECHO)'#010+
- ' @$(ECHO) == Install info =='#010+
- ' @$(ECHO)'#010+
- ' @$(ECHO) DateStr..........','.... $(DATESTR)'#010+
- ' @$(ECHO) ZipPrefix............ $(ZIPPREFIX)'#010+
- ' @$(ECHO) ZipSuffix............ $(ZIPSUFFIX)'#010+
- ' @$(ECHO) Install FPC Package.. $(INSTALL_FPCPACKAGE)'#010+
- ' @$(ECHO)'#010+
- ' @$(ECHO) Install base dir.....',' $(INSTALL_BASEDIR)'#010+
- ' @$(ECHO) Install binary dir... $(INSTALL_BINDIR)'#010+
- ' @$(ECHO) Install library dir.. $(INSTALL_LIBDIR)'#010+
- ' @$(ECHO) Install units dir.... $(INSTALL_UNITDIR)'#010+
- ' @$(ECHO) Install source dir... $(INS','TALL_SOURCEDIR)'#010+
- ' @$(ECHO) Install doc dir...... $(INSTALL_DOCDIR)'#010+
- ' @$(ECHO) Install example dir.. $(INSTALL_EXAMPLEDIR)'#010+
- ' @$(ECHO) Install data dir..... $(INSTALL_DATADIR)'#010+
- ' @$(ECHO)'#010+
- ' @$(ECHO) Dist desti','nation dir. $(DIST_DESTDIR)'#010+
- ' @$(ECHO) Dist zip name........ $(DIST_ZIPNAME)'#010+
- ' @$(ECHO)'#010+
- #010+
- '[localmakefile]'#010+
- '#####################################################################'#010+
- '# Local Makefile'#010+
- '###################################','#################################'+
- '#'#010+
- #010+
- 'ifneq ($(wildcard fpcmake.loc),)'#010+
- 'include fpcmake.loc'#010+
- 'endif'#010+
- #010+
- '[userrules]'#010+
- '#####################################################################'#010+
- '# Users rules'#010+
- '################################################','####################'+
- '#'#010
- );
|