123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998999100010011002100310041005100610071008100910101011101210131014101510161017101810191020102110221023102410251026102710281029103010311032103310341035103610371038103910401041104210431044104510461047104810491050105110521053105410551056105710581059106010611062106310641065106610671068106910701071107210731074107510761077107810791080108110821083108410851086108710881089109010911092109310941095109610971098109911001101110211031104110511061107110811091110111111121113111411151116111711181119112011211122112311241125112611271128112911301131113211331134113511361137113811391140114111421143114411451146114711481149115011511152115311541155115611571158115911601161116211631164116511661167116811691170117111721173117411751176117711781179118011811182118311841185118611871188118911901191119211931194119511961197119811991200120112021203120412051206120712081209121012111212121312141215121612171218121912201221122212231224122512261227122812291230123112321233123412351236123712381239124012411242124312441245124612471248124912501251125212531254125512561257125812591260126112621263126412651266126712681269127012711272127312741275127612771278127912801281128212831284128512861287128812891290129112921293129412951296129712981299130013011302130313041305130613071308130913101311131213131314131513161317131813191320132113221323132413251326132713281329133013311332133313341335133613371338133913401341134213431344134513461347134813491350135113521353135413551356135713581359136013611362136313641365136613671368136913701371137213731374137513761377137813791380138113821383138413851386138713881389139013911392139313941395139613971398139914001401140214031404140514061407140814091410141114121413141414151416141714181419142014211422142314241425142614271428142914301431143214331434143514361437143814391440144114421443144414451446144714481449145014511452145314541455145614571458145914601461146214631464146514661467146814691470147114721473147414751476147714781479148014811482148314841485148614871488148914901491149214931494149514961497149814991500150115021503150415051506150715081509151015111512151315141515151615171518151915201521152215231524152515261527152815291530153115321533153415351536153715381539154015411542154315441545154615471548154915501551155215531554155515561557155815591560156115621563156415651566156715681569157015711572157315741575157615771578157915801581158215831584158515861587158815891590159115921593159415951596159715981599160016011602160316041605160616071608160916101611161216131614161516161617161816191620162116221623162416251626162716281629163016311632163316341635163616371638163916401641164216431644164516461647164816491650165116521653165416551656165716581659166016611662166316641665166616671668166916701671167216731674167516761677167816791680168116821683168416851686168716881689169016911692169316941695169616971698169917001701170217031704170517061707170817091710171117121713171417151716171717181719172017211722172317241725172617271728172917301731173217331734173517361737173817391740174117421743174417451746174717481749175017511752175317541755175617571758175917601761176217631764176517661767176817691770177117721773177417751776177717781779178017811782178317841785178617871788178917901791179217931794179517961797179817991800180118021803180418051806180718081809181018111812181318141815181618171818181918201821182218231824182518261827182818291830183118321833183418351836183718381839184018411842184318441845184618471848184918501851185218531854185518561857185818591860186118621863186418651866186718681869187018711872187318741875187618771878187918801881188218831884188518861887188818891890189118921893189418951896189718981899190019011902190319041905190619071908190919101911191219131914191519161917191819191920192119221923192419251926192719281929193019311932193319341935193619371938193919401941194219431944194519461947194819491950195119521953195419551956195719581959196019611962196319641965196619671968196919701971197219731974197519761977197819791980198119821983198419851986198719881989199019911992199319941995199619971998199920002001200220032004200520062007200820092010201120122013201420152016201720182019202020212022202320242025202620272028202920302031203220332034203520362037203820392040204120422043204420452046204720482049205020512052205320542055205620572058205920602061206220632064206520662067206820692070207120722073207420752076207720782079208020812082208320842085208620872088208920902091209220932094209520962097209820992100210121022103210421052106210721082109211021112112211321142115211621172118211921202121212221232124212521262127212821292130213121322133213421352136213721382139214021412142214321442145214621472148214921502151215221532154215521562157215821592160216121622163216421652166216721682169217021712172217321742175217621772178217921802181218221832184218521862187218821892190219121922193219421952196219721982199220022012202220322042205220622072208220922102211221222132214221522162217221822192220222122222223222422252226222722282229223022312232223322342235223622372238223922402241224222432244224522462247224822492250225122522253225422552256225722582259226022612262226322642265226622672268226922702271227222732274227522762277227822792280228122822283228422852286228722882289229022912292229322942295229622972298229923002301230223032304230523062307230823092310231123122313231423152316231723182319232023212322232323242325232623272328232923302331233223332334233523362337233823392340234123422343234423452346234723482349235023512352235323542355235623572358235923602361236223632364236523662367236823692370237123722373237423752376237723782379238023812382238323842385238623872388238923902391239223932394239523962397239823992400240124022403240424052406240724082409241024112412241324142415241624172418241924202421242224232424242524262427242824292430243124322433243424352436243724382439244024412442244324442445244624472448244924502451245224532454245524562457245824592460246124622463246424652466246724682469247024712472247324742475247624772478247924802481248224832484248524862487248824892490249124922493249424952496249724982499250025012502250325042505250625072508250925102511251225132514251525162517251825192520252125222523252425252526252725282529253025312532253325342535253625372538253925402541254225432544254525462547254825492550255125522553255425552556255725582559256025612562256325642565256625672568256925702571257225732574257525762577257825792580258125822583258425852586258725882589259025912592259325942595259625972598259926002601260226032604260526062607260826092610261126122613261426152616261726182619262026212622262326242625262626272628262926302631263226332634263526362637263826392640264126422643264426452646264726482649265026512652265326542655265626572658265926602661266226632664266526662667266826692670267126722673267426752676267726782679268026812682268326842685268626872688268926902691269226932694269526962697269826992700270127022703270427052706270727082709271027112712271327142715271627172718271927202721272227232724272527262727272827292730273127322733273427352736273727382739274027412742274327442745274627472748274927502751275227532754275527562757275827592760276127622763276427652766276727682769277027712772277327742775277627772778277927802781278227832784278527862787 |
- {$ifdef Delphi}
- const fpcmakeini : array[0..271] of string[240]=(
- {$else Delphi}
- const fpcmakeini : array[0..271,1..240] of char=(
- {$endif Delphi}
- ';'#010+
- '; Templates used by fpcmake to create a Makefile from Makefile.fpc'#010+
- ';'#010+
- #010+
- '[defines]'#010+
- '#####################################################################'#010+
- '# Misc defines to be used by anyone'#010+
- '####################################################','################'+
- '#'#010+
- #010+
- '# OS categories'#010+
- 'BSDs = freebsd netbsd openbsd darwin dragonfly'#010+
- 'UNIXs = linux $(BSDs) solaris qnx haiku aix'#010+
- 'LIMIT83fs = go32v2 os2 emx watcom msdos win16 atari human68k'#010+
- 'OSNeedsComspecToRunBatch = go32v2 watcom'#010+
- #010+
- '#Empty targ','et for rules that always should run. Needed if'#010+
- '#the target is non-phoney, and there is non-phony prereqisites.'#010+
- '#Then add FORCE as an prerequisite'#010+
- '#See gnu make manual: 4.7 Rules without Commands or Prerequisites'#010+
- 'FORCE:'#010+
- '.PHONY: FORCE'#010+
- #010+
- 'lc = $','(subst A,a,$(subst B,b,$(subst C,c,$(subst D,d,$(subst E,e,$(s'+
- 'ubst F,f,$(subst G,g,$(subst H,h,$(subst I,i,$(subst J,j,$(subst K,k,$'+
- '(subst L,l,$(subst M,m,$(subst N,n,$(subst O,o,$(subst P,p,$(subst Q,q'+
- ',$(subst R,r,$(subst S,s,$(subst T,t,$','(subst U,u,$(subst V,v,$(subst'+
- ' W,w,$(subst X,x,$(subst Y,y,$(subst Z,z,$1))))))))))))))))))))))))))'#010+
- #010+
- #010+
- '[osdetect]'#010+
- '#####################################################################'#010+
- '# Autodetect source OS (Linux or Dos or Windows NT or OS/','2 or other)'+
- #010+
- '# define inUnix when running under Unix like environment'#010+
- '# (Linux,FreeBSD,NetBSD,OpenBSD,Darwin,Cygwin)'#010+
- '# define inWinNT when running under WinNT'#010+
- '# define inOS2 when running under OS/2'#010+
- '# define inCygwin when runnin','g under Cygwin32'#010+
- '#####################################################################'#010+
- #010+
- '# We need only / in the path also remove the current dir,'#010+
- '# also remove trailing /'#039's'#010+
- 'override PATH:=$(patsubst %/,%,$(subst \,/,$(PATH)))'#010+
- #010+
- '# Detect unix',#010+
- '# Darwin is handled specially'#010+
- 'ifneq ($(findstring darwin,$(OSTYPE)),)'#010+
- 'inUnix=1 #darwin'#010+
- 'SEARCHPATH:=$(filter-out .,$(subst :, ,$(PATH)))'#010+
- 'else'#010+
- '# Determine if we'#039've a unix searchpath by looking for a ;'#010+
- '# that normally doesn'#039't exists in the un','ix PATH var.'#010+
- 'ifeq ($(findstring ;,$(PATH)),)'#010+
- 'inUnix=1'#010+
- 'SEARCHPATH:=$(filter-out .,$(subst :, ,$(PATH)))'#010+
- 'else'#010+
- 'SEARCHPATH:=$(subst ;, ,$(PATH))'#010+
- 'endif'#010+
- 'endif'#010+
- #010+
- '# Add path were make is located'#010+
- 'SEARCHPATH+=$(patsubst %/,%,$(subst \,/,$(dir $(MAKE))','))'#010+
- #010+
- '# Search for PWD'#010+
- 'PWD:=$(strip $(wildcard $(addsuffix /pwd.exe,$(SEARCHPATH))))'#010+
- 'ifeq ($(PWD),)'#010+
- 'PWD:=$(strip $(wildcard $(addsuffix /pwd,$(SEARCHPATH))))'#010+
- 'ifeq ($(PWD),)'#010+
- '$(error You need the GNU utils package to use this Makefile)'#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_SHEL','L'#010+
- 'inOS2=1'#010+
- 'endif'#010+
- 'endif'#010+
- 'else'#010+
- 'ifneq ($(findstring cygdrive,$(PATH)),)'#010+
- 'inCygWin=1'#010+
- 'endif'#010+
- 'endif'#010+
- #010+
- '# The extension of batch files / scripts'#010+
- 'ifdef inUnix'#010+
- 'SRCBATCHEXT=.sh'#010+
- 'else'#010+
- 'ifdef inOS2'#010+
- 'SRCBATCHEXT=.cmd'#010+
- 'else'#010+
- 'SRCBATCHEXT=.bat'#010+
- 'endif'#010+
- 'endif'#010+
- #010+
- 'ifdef COMS','PEC'#010+
- 'ifneq ($(filter $(OS_SOURCE),$(OSNeedsComspecToRunBatch)),)'#010+
- 'ifndef RUNBATCH'#010+
- 'RUNBATCH=$(COMSPEC) /C'#010+
- 'endif'#010+
- 'endif'#010+
- 'endif'#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+
- '# cygwin bash or sh can not handle backslashes'#010+
- 'ifdef inCygWin'#010+
- 'PATHSEP=/'#010+
- 'endif'#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 inCy','gWin'#010+
- 'ifneq ($(findstring /cygdrive/,$(BASEDIR)),)'#010+
- 'BASENODIR:=$(patsubst /cygdrive%,%,$(BASEDIR))'#010+
- 'BASEDRIVE:=$(firstword $(subst /, ,$(BASENODIR)))'#010+
- 'BASEDIR:=$(subst /cygdrive/$(BASEDRIVE)/,$(BASEDRIVE):/,$(BASEDIR))'#010+
- 'endif'#010+
- 'endif'#010+
- 'else'#010+
- 'BASEDIR=','.'#010+
- 'endif'#010+
- #010+
- '# Echo is an internal command under OS/2 (and others), so it'#039's alw'+
- 'ays found'#010+
- 'ifdef inOS2'#010+
- 'ifndef ECHO'#010+
- 'ECHO:=$(strip $(wildcard $(addsuffix /gecho$(SRCEXEEXT),$(SEARCHPATH))'+
- '))'#010+
- 'ifeq ($(ECHO),)'#010+
- 'ECHO:=$(strip $(wildcard $(addsuffix /echo','$(SRCEXEEXT),$(SEARCHPATH)'+
- ')))'#010+
- 'ifeq ($(ECHO),)'#010+
- 'ECHO=echo'#010+
- 'else'#010+
- 'ECHO:=$(firstword $(ECHO))'#010+
- 'endif'#010+
- 'else'#010+
- 'ECHO:=$(firstword $(ECHO))'#010+
- 'endif'#010+
- 'endif'#010+
- 'export ECHO'#010+
- 'endif'#010+
- #010+
- '[fpcdetect]'#010+
- '#####################################################################'#010+
- '#',' FPC Binary and Version Detection'#010+
- '#####################################################################'#010+
- #010+
- '# Compatibility with old makefiles'#010+
- 'ifndef FPC'#010+
- 'ifdef PP'#010+
- 'FPC=$(PP)'#010+
- 'endif'#010+
- 'endif'#010+
- #010+
- '# Try to detect the ppcXXX file to use by using "fpc -PB"',' option'#010+
- '# to query for the default ppcXXX the fpc executable tries. When'#010+
- '# fpc is not found use ppc386 by default. Also when fpc -PB gives'#010+
- '# an error ppc386 will be used.'#010+
- 'ifndef FPC'#010+
- '# check if fpc exists'#010+
- 'FPCPROG:=$(strip $(wildcard $(addsuf','fix /fpc$(SRCEXEEXT),$(SEARCHPAT'+
- 'H))))'#010+
- 'ifneq ($(FPCPROG),)'#010+
- 'FPCPROG:=$(firstword $(FPCPROG))'#010+
- 'ifneq ($(CPU_TARGET),)'#010+
- 'FPC:=$(shell $(FPCPROG) -P$(CPU_TARGET) -PB)'#010+
- 'else'#010+
- 'FPC:=$(shell $(FPCPROG) -PB)'#010+
- 'endif'#010+
- '# Older fpc executables didn'#039't support it',' and return'#010+
- '# Error: Illegal processor... If found then fallback to ppc386'#010+
- 'ifneq ($(findstring Error,$(FPC)),)'#010+
- 'override FPC=$(firstword $(strip $(wildcard $(addsuffix /ppc386$(SRCEX'+
- 'EEXT),$(SEARCHPATH)))))'#010+
- 'else'#010+
- '# if the cross compiler is not',' found, fall back to fpc'#010+
- 'ifeq ($(strip $(wildcard $(FPC))),)'#010+
- 'FPC:=$(firstword $(FPCPROG))'#010+
- 'endif'#010+
- 'endif'#010+
- 'else'#010+
- '# fpc binary not found, fallback to ppc386'#010+
- 'override FPC=$(firstword $(strip $(wildcard $(addsuffix /ppc386$(SRCEX'+
- 'EEXT),$(SEARCHPATH))',')))'#010+
- 'endif'#010+
- 'endif'#010+
- #010+
- '# Get a clean executable name'#010+
- 'override FPC:=$(subst $(SRCEXEEXT),,$(FPC))'#010+
- 'override FPC:=$(subst \,/,$(FPC))$(SRCEXEEXT)'#010+
- #010+
- '# Try to find the binary direct first, otherwise in the path,'#010+
- '# if not found give an error'#010+
- 'FOUNDFPC:=$','(strip $(wildcard $(FPC)))'#010+
- 'ifeq ($(FOUNDFPC),)'#010+
- 'FOUNDFPC=$(strip $(wildcard $(addsuffix /$(FPC),$(SEARCHPATH))))'#010+
- 'ifeq ($(FOUNDFPC),)'#010+
- '$(error Compiler $(FPC) not found)'#010+
- 'endif'#010+
- 'endif'#010+
- #010+
- '# For 1.1 and up we can use a single compiler call to retrie','ve'#010+
- '# all needed information'#010+
- 'ifndef FPC_COMPILERINFO'#010+
- 'FPC_COMPILERINFO:=$(shell $(FPC) -iVSPTPSOTO)'#010+
- 'endif'#010+
- #010+
- '# FPC version'#010+
- 'ifndef FPC_VERSION'#010+
- 'FPC_VERSION:=$(word 1,$(FPC_COMPILERINFO))'#010+
- 'endif'#010+
- #010+
- 'export FPC FPC_VERSION FPC_COMPILERINFO'#010+
- '# CHECKDEPEN','D should not be exported'#010+
- '# This should limit multiple checks'#010+
- 'unexport CHECKDEPEND ALLDEPENDENCIES'#010+
- #010+
- '#####################################################################'#010+
- '# FPC Target Detection'#010+
- '################################################','####################'+
- '#'#010+
- #010+
- '# Fall back to default values if needed'#010+
- 'ifndef CPU_TARGET'#010+
- 'ifdef CPU_TARGET_DEFAULT'#010+
- 'CPU_TARGET=$(CPU_TARGET_DEFAULT)'#010+
- 'endif'#010+
- 'endif'#010+
- 'ifndef OS_TARGET'#010+
- 'ifdef OS_TARGET_DEFAULT'#010+
- 'OS_TARGET=$(OS_TARGET_DEFAULT)'#010+
- 'endif'#010+
- 'endif'#010+
- #010+
- '# Re','trieve Target/Source CPU and Target/Source OS'#010+
- 'ifndef CPU_SOURCE'#010+
- 'CPU_SOURCE:=$(word 2,$(FPC_COMPILERINFO))'#010+
- 'endif'#010+
- 'ifndef CPU_TARGET'#010+
- 'CPU_TARGET:=$(word 3,$(FPC_COMPILERINFO))'#010+
- 'endif'#010+
- 'ifndef OS_SOURCE'#010+
- 'OS_SOURCE:=$(word 4,$(FPC_COMPILERINFO))'#010+
- 'endi','f'#010+
- 'ifndef OS_TARGET'#010+
- 'OS_TARGET:=$(word 5,$(FPC_COMPILERINFO))'#010+
- 'endif'#010+
- #010+
- 'CPU_OS_TARGET=$(CPU_TARGET)-$(OS_TARGET)'#010+
- 'ifdef SUB_TARGET'#010+
- 'L_SUB_TARGET=$(call lc,$(SUB_TARGET))'#010+
- 'FULL_TARGET:=$(CPU_TARGET)-$(OS_TARGET)-$(L_SUB_TARGET)'#010+
- 'else'#010+
- 'FULL_TARGET:=$(C','PU_TARGET)-$(OS_TARGET)'#010+
- 'endif'#010+
- #010+
- '#'#010+
- '# not sure if we'#039'll need this, but defining it for the moment.'#010+
- '# Reason for defining it: this could redefine a "cross-compile".'#010+
- '#'#010+
- 'CPU_OS_SOURCE=$(CPU_SOURCE)-$(OS_SOURCE)'#010+
- 'ifdef SUB_SOURCE'#010+
- 'L_SUB_SOURCE=$(call',' lc,$(SUB_SOURCE))'#010+
- 'FULL_SOURCE=$(CPU_SOURCE)-$(OS_SOURCE)-$(L_SUB_SOURCE)'#010+
- 'else'#010+
- 'FULL_SOURCE=$(CPU_SOURCE)-$(OS_SOURCE)'#010+
- 'endif'#010+
- #010+
- 'ifeq ($(CPU_TARGET),armeb)'#010+
- 'ARCH=arm'#010+
- 'override FPCOPT+=-Cb'#010+
- 'else'#010+
- 'ifeq ($(CPU_TARGET),armel)'#010+
- 'ARCH=arm'#010+
- 'override FPCOPT+=','-CaEABI'#010+
- 'else'#010+
- 'ARCH=$(CPU_TARGET)'#010+
- 'endif'#010+
- 'endif'#010+
- #010+
- 'ifeq ($(CPU_OS_TARGET),aarch64-embedded)'#010+
- '# override FPCOPT+=-Cp$(SUBARCH)'#010+
- 'endif'#010+
- #010+
- 'ifdef SUB_TARGET '#010+
- 'FPCOPT+=-t$(SUB_TARGET)'#010+
- 'FPMAKE_OPT+=--subtarget=$(SUB_TARGET)'#010+
- 'endif'#010+
- #010+
- #010+
- 'ifeq ($(CPU_OS_TARGET),arm','-embedded)'#010+
- 'ifeq ($(SUBARCH),)'#010+
- '# we don'#039't add a default here, people should explicitly add the SU'+
- 'BARCH'#010+
- '$(error When compiling for arm-embedded, a sub-architecture (e.g. SUBA'+
- 'RCH=armv4t or SUBARCH=armv7m) must be defined)'#010+
- 'endif'#010+
- 'override FPCOPT','+=-Cp$(SUBARCH)'#010+
- 'endif'#010+
- #010+
- 'ifeq ($(CPU_OS_TARGET),avr-embedded)'#010+
- 'ifeq ($(SUBARCH),)'#010+
- '# we don'#039't add a default here, people should explicitly add the SU'+
- 'BARCH'#010+
- '$(error When compiling for avr-embedded, a sub-architecture (e.g. SUBA'+
- 'RCH=avr25 or SUBARC','H=avr35) must be defined)'#010+
- 'endif'#010+
- 'override FPCOPT+=-Cp$(SUBARCH)'#010+
- 'endif'#010+
- #010+
- 'ifeq ($(CPU_OS_TARGET),mipsel-embedded)'#010+
- 'ifeq ($(SUBARCH),)'#010+
- '# we don'#039't add a default here, people should explicitly add the SU'+
- 'BARCH'#010+
- '$(error When compiling for mipsel-embed','ded, a sub-architecture (e.g.'+
- ' SUBARCH=pic32mx) must be defined)'#010+
- 'endif'#010+
- 'override FPCOPT+=-Cp$(SUBARCH)'#010+
- 'endif'#010+
- #010+
- 'ifeq ($(CPU_OS_TARGET),xtensa-embedded)'#010+
- 'ifeq ($(SUBARCH),)'#010+
- '$(error When compiling for xtensa-embedded, a sub-architecture (e.g. S'+
- 'UBA','RCH=lx106 or SUBARCH=lx6) must be defined)'#010+
- 'endif'#010+
- 'override FPCOPT+=-Cp$(SUBARCH)'#010+
- 'endif'#010+
- #010+
- 'ifeq ($(CPU_OS_TARGET),xtensa-freertos)'#010+
- 'ifeq ($(SUBARCH),)'#010+
- '$(error When compiling for xtensa-freertos, a sub-architecture (e.g. S'+
- 'UBARCH=lx106 or SUBARCH=','lx6) must be defined)'#010+
- 'endif'#010+
- 'override FPCOPT+=-Cp$(SUBARCH)'#010+
- 'endif'#010+
- #010+
- 'ifeq ($(CPU_OS_TARGET),arm-freertos)'#010+
- 'ifeq ($(SUBARCH),)'#010+
- '$(error When compiling for arm-freertos, a sub-architecture (e.g. SUBA'+
- 'RCH=armv6m or SUBARCH=armv7em) must be defined)'#010,
- 'endif'#010+
- 'override FPCOPT+=-Cp$(SUBARCH)'#010+
- 'endif'#010+
- #010+
- '# Full name of the target, including CPU and OS. For OSs limited'#010+
- '# to 8.3 we only use the target OS'#010+
- 'ifneq ($(filter $(OS_SOURCE),$(LIMIT83fs)),)'#010+
- 'TARGETSUFFIX=$(OS_TARGET)'#010+
- 'SOURCESUFFIX=$(OS_SOURCE)',#010+
- 'else'#010+
- 'ifneq ($(filter $(OS_TARGET),$(LIMIT83fs)),)'#010+
- 'TARGETSUFFIX=$(OS_TARGET)'#010+
- 'else'#010+
- 'TARGETSUFFIX=$(FULL_TARGET)'#010+
- 'endif'#010+
- 'SOURCESUFFIX=$(FULL_SOURCE)'#010+
- 'endif'#010+
- #010+
- '# Cross compile flag'#010+
- '#'#010+
- '# We may need to switch to FULL_TARGET/FULL_TARGET'#010+
- '#'#010+
- 'ifneq ($(CPU_','OS_TARGET),$(CPU_OS_SOURCE))'#010+
- 'CROSSCOMPILE=1'#010+
- 'endif'#010+
- #010+
- '# Check if the Makefile supports this target, but not'#010+
- '# when the make target is to rebuild the makefile'#010+
- 'ifeq ($(findstring makefile,$(MAKECMDGOALS)),)'#010+
- 'ifeq ($(filter $(CPU_OS_TARGET),$(MAKE','FILETARGETS)),)'#010+
- '$(error The Makefile doesn'#039't support target $(FULL_TARGET), please'+
- ' run fpcmake first)'#010+
- 'endif'#010+
- 'endif'#010+
- #010+
- #010+
- '# Detect BSD, since BSD uses a slightly different directory hierarchy.'+
- #010+
- 'ifneq ($(filter $(OS_TARGET),$(BSDs)),)'#010+
- 'BSDhier=1'#010+
- 'end','if'#010+
- #010+
- '# Detect Linux, will also use its own directory hierarchy.'#010+
- 'ifeq ($(OS_TARGET),linux)'#010+
- 'linuxHier=1'#010+
- 'endif'#010+
- #010+
- 'ifndef CROSSCOMPILE'#010+
- 'BUILDFULLNATIVE=1'#010+
- 'export BUILDFULLNATIVE'#010+
- 'endif'#010+
- #010+
- 'ifdef BUILDFULLNATIVE'#010+
- 'BUILDNATIVE=1'#010+
- 'export BUILDNATIVE'#010+
- 'endif'#010+
- #010+
- 'ex','port OS_TARGET OS_SOURCE ARCH CPU_TARGET CPU_SOURCE SUB_TARGET SUB'+
- '_SOURCE FULL_TARGET FULL_SOURCE TARGETSUFFIX SOURCESUFFIX CROSSCOMPILE'+
- ' CPU_OS_TARGET CPU_OS_SOURCE'#010+
- #010+
- '[fpmakefpcdetect]'#010+
- '########################################################','############'+
- '#'#010+
- '# FPC Binary and Version Detection'#010+
- '#####################################################################'#010+
- '# If FPCFPMAKE is not set and we'#039're cross-compiling, try to find a'+
- #010+
- '# native compiler.'#010+
- 'ifndef FPCFPMAKE'#010+
- #010+
- 'ifdef CROSSCOMPIL','E'#010+
- '# Search for the (native) ppc compiler which is used to do the latest '+
- 'build'#010+
- '# of the native rtl'#010+
- #010+
- 'ifeq ($(strip $(wildcard $(addsuffix /compiler/ppc$(SRCEXEEXT),$(FPCDI'+
- 'R)))),)'#010+
- '# If that compiler is not found, use the common, installed nati','ve co'+
- 'mpiler'#010+
- '# Note that in this case FPCFPMAKE is not exported, because it could b'+
- 'e that'#010+
- '# a more suitable compiler is compiled later on'#010+
- '# check if fpc exists'#010+
- 'FPCPROG:=$(strip $(wildcard $(addsuffix /fpc$(SRCEXEEXT),$(SEARCHPATH)'+
- ')))'#010+
- 'ifneq (','$(FPCPROG),)'#010+
- 'FPCPROG:=$(firstword $(FPCPROG))'#010+
- 'FPCFPMAKE:=$(shell $(FPCPROG) -PB)'#010+
- '# if a native compiler is not found, fall back to fpc'#010+
- 'ifeq ($(strip $(wildcard $(FPCFPMAKE))),)'#010+
- 'FPCFPMAKE:=$(firstword $(FPCPROG))'#010+
- 'endif'#010+
- 'else'#010+
- '# fpc binary not ','found, fallback to ppc386'#010+
- 'override FPCFPMAKE=$(firstword $(strip $(wildcard $(addsuffix /ppc386$'+
- '(SRCEXEEXT),$(SEARCHPATH)))))'#010+
- 'endif'#010+
- 'else'#010+
- '# Use the ppc compiler. Because the path to the compiler is relative, '+
- 'do not'#010+
- '# evaluate the variable he','re, but do that on the fly.'#010+
- 'FPCFPMAKE=$(strip $(wildcard $(addsuffix /compiler/ppc$(SRCEXEEXT),$(F'+
- 'PCDIR))))'#010+
- 'FPMAKE_SKIP_CONFIG=-n'#010+
- 'export FPCFPMAKE'#010+
- 'export FPMAKE_SKIP_CONFIG'#010+
- 'endif'#010+
- #010+
- 'else'#010+
- 'FPMAKE_SKIP_CONFIG=-n'#010+
- 'FPCFPMAKE=$(FPC)'#010+
- 'endif'#010+
- #010+
- 'endif'#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)),)'#010+
- 'override FPCDIR=wrong'#010+
- 'endif'#010+
- 'else'#010+
- 'override FPCDIR=wrong'#010+
- 'endif'#010+
- #010+
- '# Default FPCDIR from Makefile.fpc'#010+
- 'ifdef DEFAULT_FPCDIR'#010+
- 'ifeq ($(FPCDIR),wrong)'#010+
- 'override FPCDIR:=$(s','ubst \,/,$(DEFAULT_FPCDIR))'#010+
- 'ifeq ($(wildcard $(addprefix $(FPCDIR)/,rtl)),)'#010+
- 'override FPCDIR=wrong'#010+
- 'endif'#010+
- 'endif'#010+
- 'endif'#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+
- 'override FPCDIR:=$(FPCDIR)/..'#010+
- 'ifeq ($(wildcard $(ad','dprefix $(FPCDIR)/,rtl)),)'#010+
- 'override FPCDIR:=$(FPCDIR)/..'#010+
- 'ifeq ($(wildcard $(addprefix $(FPCDIR)/,rtl)),)'#010+
- 'override FPCDIR:=$(BASEDIR)'#010+
- 'ifeq ($(wildcard $(addprefix $(FPCDIR)/,rtl)),)'#010+
- 'override FPCDIR=c:/pp'#010+
- 'endif'#010+
- 'endif'#010+
- 'endif'#010+
- 'endif'#010+
- 'endif'#010+
- #010+
- '# Cros','s binaries dir'#010+
- 'ifndef CROSSBINDIR'#010+
- 'CROSSBINDIR:=$(wildcard $(FPCDIR)/bin/$(TARGETSUFFIX))'#010+
- 'endif'#010+
- #010+
- '# Default binutils prefix for cross compile when the'#010+
- '# crossbindir is not set (except for Darwin)'#010+
- 'ifneq ($(filter $(OS_TARGET),darwin iphonesim ','ios),)'#010+
- 'ifneq ($(filter $(OS_SOURCE),darwin ios),)'#010+
- 'DARWIN2DARWIN=1'#010+
- 'endif'#010+
- 'endif'#010+
- #010+
- 'ifndef BINUTILSPREFIX'#010+
- 'ifndef CROSSBINDIR'#010+
- 'ifdef CROSSCOMPILE'#010+
- 'ifneq ($(OS_TARGET),msdos)'#010+
- 'ifndef DARWIN2DARWIN'#010+
- 'ifneq ($(CPU_TARGET),jvm)'#010+
- 'BINUTILSPREFIX=$(CPU_TARGET',')-$(OS_TARGET)-'#010+
- #010+
- '# For Android use standard NDK prefixes'#010+
- 'ifeq ($(OS_TARGET),android)'#010+
- 'ifeq ($(CPU_TARGET),arm)'#010+
- 'BINUTILSPREFIX=arm-linux-androideabi-'#010+
- 'else'#010+
- 'ifeq ($(CPU_TARGET),i386)'#010+
- 'BINUTILSPREFIX=i686-linux-android-'#010+
- 'else'#010+
- 'BINUTILSPREFIX=$(CPU_','TARGET)-linux-android-'#010+
- 'endif'#010+
- 'endif'#010+
- 'endif'#010+
- #010+
- 'endif'#010+
- 'endif'#010+
- 'else'#010+
- 'BINUTILSPREFIX=$(OS_TARGET)-'#010+
- 'endif'#010+
- 'endif'#010+
- 'endif'#010+
- 'endif'#010+
- #010+
- '# Try first the full target name, otherwise try only'#010+
- '# the OS for backwards compatibility'#010+
- 'UNITSDIR:=$(wildcard $(FPCDIR)/units/','$(TARGETSUFFIX))'#010+
- 'ifeq ($(UNITSDIR),)'#010+
- 'UNITSDIR:=$(wildcard $(FPCDIR)/units/$(OS_TARGET))'#010+
- 'endif'#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+
- 'ifndef inUnix'#010+
- 'ECHOREDIR=echo'#010+
- 'else'#010+
- 'ECHOREDIR=$(ECHO)'#010+
- 'endif'#010+
- 'endif'#010,
- #010+
- '# To copy pograms'#010+
- 'ifndef COPY'#010+
- 'COPY:=$(CPPROG) -fp'#010+
- 'endif'#010+
- #010+
- '# Copy a whole tree'#010+
- 'ifndef COPYTREE'#010+
- 'COPYTREE:=$(CPPROG) -Rfp'#010+
- 'endif'#010+
- #010+
- '# Copy a whole tree'#010+
- 'ifndef MKDIRTREE'#010+
- 'MKDIRTREE:=$(MKDIRPROG) -p'#010+
- 'endif'#010+
- #010+
- '# To move pograms'#010+
- 'ifndef MOVE'#010+
- 'MOVE:=$(MVPRO','G) -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 install 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 make a directory.'#010+
- 'ifndef MKDIR'#010+
- 'MKDIR:=$(GINSTALL) -m 755 -d'#010+
- 'endif'#010+
- #010+
- 'export ECHOREDIR COPY COPYTRE','E MOVE DEL DELTREE INSTALL INSTALLEXE M'+
- 'KDIR'#010+
- #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+
- '# Unixes use unix dirs with /usr/bin, /usr/lib'#010+
- '# When zipping use the target os defau','lt, when normal install then'#010+
- '# use the source os as default'#010+
- 'ifdef ZIPINSTALL'#010+
- '# Zipinstall'#010+
- 'ifneq ($(filter $(OS_TARGET),$(UNIXs)),)'#010+
- 'UNIXHier=1'#010+
- 'endif'#010+
- 'else'#010+
- '# Normal install'#010+
- 'ifneq ($(filter $(OS_SOURCE),$(UNIXs)),)'#010+
- 'UNIXHier=1'#010+
- 'endif'#010+
- 'endif'#010+
- #010+
- '# Whe','n install prefix is not set try to use prefix'#010+
- 'ifndef INSTALL_PREFIX'#010+
- 'ifdef PREFIX'#010+
- 'INSTALL_PREFIX=$(PREFIX)'#010+
- 'endif'#010+
- 'endif'#010+
- #010+
- '# set the prefix directory where to install everything'#010+
- 'ifndef INSTALL_PREFIX'#010+
- 'ifdef UNIXHier'#010+
- 'INSTALL_PREFIX=/usr/local'#010+
- 'els','e'#010+
- 'ifdef INSTALL_FPCPACKAGE'#010+
- 'INSTALL_BASEDIR:=/pp'#010+
- 'else'#010+
- 'INSTALL_BASEDIR:=/$(PACKAGE_NAME)'#010+
- 'endif'#010+
- 'endif'#010+
- 'endif'#010+
- 'export INSTALL_PREFIX'#010+
- #010+
- '# Export also INSTALL_SOURCESUBDIR set so it will be'#010+
- '# used recursively for all subdirs'#010+
- 'ifdef INSTALL_FPCSUBDIR'#010,
- 'export INSTALL_FPCSUBDIR'#010+
- 'endif'#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+
- '# EXE/PPU Target directories'#010+
- 'ifndef COMPILER_UNITTARGETDIR'#010+
- 'ifdef PACKAGEDIR_MAIN'#010+
- 'COMPILER_UNITT','ARGETDIR=$(PACKAGEDIR_MAIN)/units/$(TARGETSUFFIX)'#010+
- 'else'#010+
- 'COMPILER_UNITTARGETDIR=units/$(TARGETSUFFIX)'#010+
- 'endif'#010+
- 'endif'#010+
- 'ifndef COMPILER_TARGETDIR'#010+
- 'COMPILER_TARGETDIR=.'#010+
- 'endif'#010+
- #010+
- #010+
- '#####################################################################'#010+
- '# I','nstall Directories'#010+
- '#####################################################################'#010+
- #010+
- '# set the base directory where to install everything'#010+
- 'ifndef INSTALL_BASEDIR'#010+
- 'ifdef UNIXHier'#010+
- 'ifdef 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 UNIXHier'#010+
- 'INSTALL_BI','NDIR:=$(INSTALL_PREFIX)/bin'#010+
- 'else'#010+
- 'INSTALL_BINDIR:=$(INSTALL_BASEDIR)/bin'#010+
- '# for FPC packages install the binaries under their target subdir'#010+
- 'ifdef INSTALL_FPCPACKAGE'#010+
- 'ifdef CROSSCOMPILE'#010+
- 'ifdef CROSSINSTALL'#010+
- 'INSTALL_BINDIR:=$(INSTALL_BINDIR)/$(SOU','RCESUFFIX)'#010+
- 'else'#010+
- 'INSTALL_BINDIR:=$(INSTALL_BINDIR)/$(TARGETSUFFIX)'#010+
- 'endif'#010+
- 'else'#010+
- 'INSTALL_BINDIR:=$(INSTALL_BINDIR)/$(TARGETSUFFIX)'#010+
- 'endif'#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/$(TARGETSUFFIX)'#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 UNIXHier'#010+
- 'INSTALL_LIB','DIR:=$(INSTALL_PREFIX)/lib'#010+
- 'else'#010+
- 'INSTALL_LIBDIR:=$(INSTALL_UNITDIR)'#010+
- 'endif'#010+
- 'endif'#010+
- #010+
- '# Where the source files will be stored'#010+
- 'ifndef INSTALL_SOURCEDIR'#010+
- 'ifdef UNIXHier'#010+
- 'ifdef BSDhier'#010+
- 'SRCPREFIXDIR=share/src'#010+
- 'else'#010+
- 'ifdef linuxHier'#010+
- 'SRCPREFIXDIR=share/src',#010+
- 'else'#010+
- 'SRCPREFIXDIR=src'#010+
- 'endif'#010+
- 'endif'#010+
- 'ifdef INSTALL_FPCPACKAGE'#010+
- 'ifdef INSTALL_FPCSUBDIR'#010+
- 'INSTALL_SOURCEDIR:=$(INSTALL_PREFIX)/$(SRCPREFIXDIR)/fpc-$(FPC_VERSION'+
- ')/$(INSTALL_FPCSUBDIR)/$(PACKAGE_NAME)'#010+
- 'else'#010+
- 'INSTALL_SOURCEDIR:=$(INSTALL_PREFIX)/$(SRC','PREFIXDIR)/fpc-$(FPC_VERSI'+
- 'ON)/$(PACKAGE_NAME)'#010+
- 'endif'#010+
- 'else'#010+
- 'INSTALL_SOURCEDIR:=$(INSTALL_PREFIX)/$(SRCPREFIXDIR)/$(PACKAGE_NAME)-$'+
- '(PACKAGE_VERSION)'#010+
- 'endif'#010+
- 'else'#010+
- 'ifdef INSTALL_FPCPACKAGE'#010+
- 'ifdef INSTALL_FPCSUBDIR'#010+
- 'INSTALL_SOURCEDIR:=$(INSTALL_BASEDI','R)/source/$(INSTALL_FPCSUBDIR)/$('+
- 'PACKAGE_NAME)'#010+
- 'else'#010+
- 'INSTALL_SOURCEDIR:=$(INSTALL_BASEDIR)/source/$(PACKAGE_NAME)'#010+
- 'endif'#010+
- 'else'#010+
- 'INSTALL_SOURCEDIR:=$(INSTALL_BASEDIR)/source'#010+
- 'endif'#010+
- 'endif'#010+
- 'endif'#010+
- #010+
- '# Where the doc files will be stored'#010+
- 'ifndef INSTALL_','DOCDIR'#010+
- 'ifdef UNIXHier'#010+
- 'ifdef BSDhier'#010+
- 'DOCPREFIXDIR=share/doc'#010+
- 'else'#010+
- 'ifdef linuxHier'#010+
- 'DOCPREFIXDIR=share/doc'#010+
- 'else'#010+
- 'DOCPREFIXDIR=doc'#010+
- 'endif'#010+
- 'endif'#010+
- 'ifdef INSTALL_FPCPACKAGE'#010+
- 'INSTALL_DOCDIR:=$(INSTALL_PREFIX)/$(DOCPREFIXDIR)/fpc-$(FPC_VERSION)/$'+
- '(PACKAGE','_NAME)'#010+
- 'else'#010+
- 'INSTALL_DOCDIR:=$(INSTALL_PREFIX)/$(DOCPREFIXDIR)/$(PACKAGE_NAME)-$(PA'+
- 'CKAGE_VERSION)'#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+
- 'en','dif'#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 UNIXHier'#010+
- 'ifdef INSTALL_FPCPACKAGE'#010+
- #010+
- 'ifdef BSDhier'#010+
- 'INSTALL_EXAMPLEDIR:=$(INS','TALL_PREFIX)/share/examples/fpc-$(FPC_VERSI'+
- 'ON)/$(PACKAGE_NAME)'#010+
- 'else'#010+
- 'ifdef linuxHier'#010+
- 'INSTALL_EXAMPLEDIR:=$(INSTALL_DOCDIR)/examples'#010+
- 'else'#010+
- 'INSTALL_EXAMPLEDIR:=$(INSTALL_PREFIX)/doc/fpc-$(FPC_VERSION)/examples/'+
- '$(PACKAGE_NAME)'#010+
- 'endif'#010+
- 'endif'#010+
- #010+
- 'else'#010,
- #010+
- 'ifdef BSDhier'#010+
- 'INSTALL_EXAMPLEDIR:=$(INSTALL_PREFIX)/share/examples/$(PACKAGE_NAME)-$'+
- '(PACKAGE_VERSION)'#010+
- 'else'#010+
- 'ifdef linuxHier'#010+
- 'INSTALL_EXAMPLEDIR:=$(INSTALL_DOCDIR)/examples/$(PACKAGE_NAME)-$(PACKA'+
- 'GE_VERSION)'#010+
- 'else'#010+
- 'INSTALL_EXAMPLEDIR:=$(INSTALL','_PREFIX)/doc/$(PACKAGE_NAME)-$(PACKAGE_'+
- 'VERSION)'#010+
- 'endif'#010+
- #010+
- 'endif'#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+
- 'INSTALL_DATADIR=$(INSTALL_BASEDIR)'#010+
- 'endif'#010+
- #010+
- 'ifndef INSTALL_SHAREDDIR'#010+
- 'INSTALL_SHAREDDIR=$(INSTALL_PREFIX)/lib'#010+
- 'endif'#010+
- #010+
- '############################################################','########'+
- '#'#010+
- '# Cross compile dirs'#010+
- '#####################################################################'#010+
- #010+
- 'ifdef CROSSCOMPILE'#010+
- '# Directory where the cross compile tools are stored.'#010+
- '# First check if they are available in FPCDIR. If no targets/ sub','dir'+
- #010+
- '# is found use the targets/ subdir in INSTALL_BASEDIR.'#010+
- 'ifndef CROSSBINDIR'#010+
- 'CROSSBINDIR:=$(wildcard $(CROSSTARGETDIR)/bin/$(SOURCESUFFIX))'#010+
- 'ifeq ($(CROSSBINDIR),)'#010+
- 'CROSSBINDIR:=$(wildcard $(INSTALL_BASEDIR)/cross/$(TARGETSUFFIX)/bin/$'+
- '(FULL_','SOURCE))'#010+
- 'endif'#010+
- 'endif'#010+
- 'else'#010+
- 'CROSSBINDIR='#010+
- 'endif'#010+
- #010+
- #010+
- '[dirlibc]'#010+
- '# On linux, try to find where libgcc.a is.'#010+
- 'ifeq ($(OS_SOURCE),linux)'#010+
- 'ifndef GCCLIBDIR'#010+
- '# Amd64 to i386?'#010+
- 'ifeq ($(CPU_TARGET),i386)'#010+
- 'ifneq ($(filter x86_64,$(shell uname -a)),)'#010+
- 'ifeq ($(BI','NUTILSPREFIX),)'#010+
- 'GCCLIBDIR:=$(shell dirname `gcc -m32 -print-libgcc-file-name`)'#010+
- 'else'#010+
- 'CROSSGCCOPT=-m32'#010+
- 'endif'#010+
- '#BINUTILSPREFIX'#010+
- 'endif'#010+
- '#filter x86_64'#010+
- 'endif'#010+
- '#CPU_TARGET=i386'#010+
- 'ifeq ($(CPU_TARGET),powerpc)'#010+
- 'ifeq ($(BINUTILSPREFIX),)'#010+
- 'GCCLIBDIR:=$(shell',' dirname `gcc -m32 -print-libgcc-file-name`)'#010+
- 'else'#010+
- 'CROSSGCCOPT=-m32'#010+
- 'endif'#010+
- '#BINUTILSPREFIX'#010+
- 'endif'#010+
- '#CPU_TARGET=powerpc'#010+
- 'ifeq ($(CPU_TARGET),powerpc64)'#010+
- 'ifeq ($(BINUTILSPREFIX),)'#010+
- 'GCCLIBDIR:=$(shell dirname `gcc -m64 -print-libgcc-file-name`)'#010+
- 'else'#010,
- 'CROSSGCCOPT=-m64'#010+
- 'endif'#010+
- '#BINUTILSPREFIX'#010+
- 'endif'#010+
- '#CPU_TARGET=powerpc64'#010+
- 'ifeq ($(CPU_TARGET),sparc)'#010+
- 'ifneq ($(filter sparc64,$(shell uname -a)),)'#010+
- 'ifeq ($(BINUTILSPREFIX),)'#010+
- 'GCCLIBDIR:=$(shell dirname `gcc -m32 -print-libgcc-file-name`)'#010+
- 'else'#010+
- 'CROSSGC','COPT=-m32'#010+
- 'endif'#010+
- '#BINUTILSPREFIX'#010+
- 'endif'#010+
- '#filter sparc64'#010+
- 'endif'#010+
- '#CPU_TARGET=sparc'#010+
- '# gcc mips seems not to recognize -m32/-m64'#010+
- 'ifneq ($(filter $(CPU_TARGET),mips64 mipsel64),)'#010+
- 'ifeq ($(BINUTILSPREFIX),)'#010+
- 'GCCLIBDIR:=$(shell dirname `gcc -mabi=64 -p','rint-libgcc-file-name`)'#010+
- 'else'#010+
- 'CROSSGCCOPT=-mabi=64'#010+
- 'endif'#010+
- '#BINUTILSPREFIX'#010+
- 'endif'#010+
- '#CPU_TARGET=mips64,mips64el'#010+
- '# gcc mips seems not to recognize -m32/-m64'#010+
- 'ifneq ($(filter $(CPU_TARGET),mips mipsel),)'#010+
- 'ifeq ($(BINUTILSPREFIX),)'#010+
- 'GCCLIBDIR:=$(shell ','dirname `gcc -mabi=32 -print-libgcc-file-name`)'#010+
- 'else'#010+
- 'CROSSGCCOPT=-mabi=32'#010+
- 'endif'#010+
- '#BINUTILSPREFIX'#010+
- 'endif'#010+
- '#CPU_TARGET=mips,mipsel'#010+
- 'ifeq ($(BINUTILSPREFIX),)'#010+
- 'ifeq ($(GCCLIBDIR),)'#010+
- 'GCCLIBDIR:=$(shell dirname `gcc -print-libgcc-file-name`)'#010+
- 'endif'#010+
- '#GC','CLIBDIR='#010+
- 'else'#010+
- 'ifeq ($(CROSSGCCOPT),)'#010+
- 'CROSSGCCOPT=-g'#010+
- 'endif'#010+
- '#CROSSGCCOPT='#010+
- 'endif'#010+
- '#BINUTILSPREFIX'#010+
- 'endif'#010+
- '#GCCLIBDIR='#010+
- #010+
- '# Check if FPCFPMAKE compiler is same target as FPC'#010+
- 'ifdef FPCFPMAKE'#010+
- 'FPCFPMAKE_CPU_TARGET=$(shell $(FPCFPMAKE) -iTP)'#010+
- 'ifeq ($(CPU','_TARGET),$(FPCFPMAKE_CPU_TARGET))'#010+
- '# In that case use GCCLIBDIR value for FPCMAKEGCCLIBDIR'#010+
- 'FPCMAKEGCCLIBDIR:=$(GCCLIBDIR)'#010+
- 'else'#010+
- 'ifneq ($(filter $(FPCFPMAKE_CPU_TARGET),aarch64 powerpc64 riscv64 spar'+
- 'c64 x86_64 loongarch64),)'#010+
- 'FPCMAKE_CROSSGCCOP','T=-m64'#010+
- 'else'#010+
- 'ifneq ($(filter $(FPCFPMAKE_CPU_TARGET),mips64 mips64el),)'#010+
- 'FPCMAKE_CROSSGCCOPT=-mabi=64'#010+
- 'else'#010+
- 'ifneq ($(filter $(FPCFPMAKE_CPU_TARGET),mips mipsel),)'#010+
- 'FPCMAKE_CROSSGCCOPT=-mabi=32'#010+
- 'else'#010+
- 'ifeq ($(FPCFPMAKE_CPU_TARGET),riscv64)'#010+
- 'FPCMAKE','_CROSSGCCOPT=-mabi=lp64'#010+
- 'else'#010+
- 'ifeq ($(FPCFPMAKE_CPU_TARGET),riscv32)'#010+
- 'FPCMAKE_CROSSGCCOPT=-mabi=ilp32'#010+
- 'else'#010+
- 'ifeq ($(FPCFPMAKE_CPU_TARGET),loongarch64)'#010+
- 'FPCMAKE_CROSSGCCOPT=-mabi=lp64d'#010+
- 'else'#010+
- 'FPCMAKE_CROSSGCCOPT=-m32'#010+
- 'endif'#010+
- '#loongarch64'#010+
- 'endif'#010+
- '#risc','v32'#010+
- 'endif'#010+
- '#riscv64'#010+
- 'endif'#010+
- '#mips/mipsel'#010+
- 'endif'#010+
- '#mips64/mips64el'#010+
- 'endif'#010+
- '#64-bit targets'#010+
- 'FPCMAKEGCCLIBDIR:=$(shell dirname `gcc $(FPCMAKE_CROSSGCCOPT) -print-l'+
- 'ibgcc-file-name`)'#010+
- 'endif'#010+
- '#not CPU_TARGET=FPCFPMAKE_CPU_TARGET'#010+
- 'endif'#010+
- '#def FPCFPMAKE'#010+
- #010+
- 'ifnd','ef FPCMAKEGCCLIBDIR'#010+
- 'FPCMAKEGCCLIBDIR:=$(shell dirname `gcc -print-libgcc-file-name`)'#010+
- 'endif'#010+
- #010+
- '# Try cross gcc'#010+
- 'ifndef GCCLIBDIR'#010+
- 'CROSSGCC=$(strip $(wildcard $(addsuffix /$(BINUTILSPREFIX)gcc$(SRCEXEE'+
- 'XT),$(SEARCHPATH))))'#010+
- 'ifneq ($(CROSSGCC),)'#010+
- 'GCC','LIBDIR:=$(shell dirname `$(CROSSGCC) $(CROSSGCCOPT) -print-libgcc'+
- '-file-name`)'#010+
- 'endif'#010+
- '#CROSSGCC='#010+
- 'endif'#010+
- '#ndef GCCLIBDIR'#010+
- 'endif'#010+
- '#ifeq($(OS_SOURCE),linux)'#010+
- #010+
- 'ifdef inUnix'#010+
- 'ifeq ($(OS_SOURCE),netbsd)'#010+
- 'OTHERLIBDIR:=/usr/pkg/lib'#010+
- 'endif'#010+
- 'export GCCLIBDIR F','PCMAKEGCCLIBDIR OTHERLIBDIR'#010+
- 'endif'#010+
- #010+
- #010+
- '[extensions]'#010+
- '#####################################################################'#010+
- '# Default extensions'#010+
- '#####################################################################'#010+
- #010+
- '# Default needed extensions (','Go32v2,Linux)'#010+
- 'BATCHEXT=.bat'#010+
- 'LOADEREXT=.as'#010+
- 'EXEEXT=.exe'#010+
- 'PPLEXT=.ppl'#010+
- 'PPUEXT=.ppu'#010+
- 'OEXT=.o'#010+
- 'LTOEXT=.bc'#010+
- 'ASMEXT=.s'#010+
- 'SMARTEXT=.sl'#010+
- 'STATICLIBEXT=.a'#010+
- 'SHAREDLIBEXT=.so'#010+
- 'SHAREDLIBPREFIX=libfp'#010+
- 'STATICLIBPREFIX=libp'#010+
- 'IMPORTLIBPREFIX=libimp'#010+
- 'RSTEXT=.rsj'#010+
- '# externa','l debug info for executable'#010+
- 'EXEDBGEXT=.dbg'#010+
- '#DEBUGSYMEXT #for debugger symbol files, define only for targets which'+
- ' has this'#010+
- 'ALL_EXEEXT=.exe'#010+
- #010+
- '# Go32v1'#010+
- 'ifeq ($(OS_TARGET),go32v1)'#010+
- 'STATICLIBPREFIX='#010+
- 'SHORTSUFFIX=v1'#010+
- 'endif'#010+
- #010+
- '# Go32v2'#010+
- 'ifeq ($(OS_TARGE','T),go32v2)'#010+
- 'STATICLIBPREFIX='#010+
- 'SHORTSUFFIX=dos'#010+
- 'IMPORTLIBPREFIX='#010+
- 'endif'#010+
- #010+
- '# watcom'#010+
- 'ifeq ($(OS_TARGET),watcom)'#010+
- 'STATICLIBPREFIX='#010+
- 'OEXT=.obj'#010+
- 'ASMEXT=.asm'#010+
- 'SHAREDLIBEXT=.dll'#010+
- 'SHORTSUFFIX=wat'#010+
- 'IMPORTLIBPREFIX='#010+
- 'endif'#010+
- #010+
- '# Android native'#010+
- 'ifneq ($(CPU_TARGET),j','vm)'#010+
- 'ifeq ($(OS_TARGET),android)'#010+
- 'BATCHEXT=.sh'#010+
- 'EXEEXT='#010+
- 'HASSHAREDLIB=1'#010+
- 'SHORTSUFFIX=lnx'#010+
- 'endif'#010+
- 'endif'#010+
- #010+
- '# Linux'#010+
- 'ifeq ($(OS_TARGET),linux)'#010+
- 'BATCHEXT=.sh'#010+
- 'EXEEXT='#010+
- 'HASSHAREDLIB=1'#010+
- 'SHORTSUFFIX=lnx'#010+
- 'endif'#010+
- #010+
- '# DragonFly BSD'#010+
- 'ifeq ($(OS_TARGET),dragonfly)'#010+
- 'BATC','HEXT=.sh'#010+
- 'EXEEXT='#010+
- 'HASSHAREDLIB=1'#010+
- 'SHORTSUFFIX=df'#010+
- 'endif'#010+
- #010+
- '# FreeBSD'#010+
- 'ifeq ($(OS_TARGET),freebsd)'#010+
- 'BATCHEXT=.sh'#010+
- 'EXEEXT='#010+
- 'HASSHAREDLIB=1'#010+
- 'SHORTSUFFIX=fbs'#010+
- 'endif'#010+
- #010+
- '# NetBSD'#010+
- 'ifeq ($(OS_TARGET),netbsd)'#010+
- 'BATCHEXT=.sh'#010+
- 'EXEEXT='#010+
- 'HASSHAREDLIB=1'#010+
- 'SHORTSUFFIX=nbs'#010+
- 'e','ndif'#010+
- #010+
- '# OpenBSD'#010+
- 'ifeq ($(OS_TARGET),openbsd)'#010+
- 'BATCHEXT=.sh'#010+
- 'EXEEXT='#010+
- 'HASSHAREDLIB=1'#010+
- 'SHORTSUFFIX=obs'#010+
- 'endif'#010+
- #010+
- '# Win32'#010+
- 'ifeq ($(OS_TARGET),win32)'#010+
- 'SHAREDLIBEXT=.dll'#010+
- 'SHORTSUFFIX=w32'#010+
- 'endif'#010+
- #010+
- '# OS/2'#010+
- 'ifeq ($(OS_TARGET),os2)'#010+
- 'BATCHEXT=.cmd'#010+
- 'AOUTEXT=.out'#010+
- 'STAT','ICLIBPREFIX='#010+
- 'SHAREDLIBEXT=.dll'#010+
- 'SHORTSUFFIX=os2'#010+
- 'ECHO=echo'#010+
- 'IMPORTLIBPREFIX='#010+
- 'endif'#010+
- #010+
- '# EMX'#010+
- 'ifeq ($(OS_TARGET),emx)'#010+
- 'BATCHEXT=.cmd'#010+
- 'AOUTEXT=.out'#010+
- 'STATICLIBPREFIX='#010+
- 'SHAREDLIBEXT=.dll'#010+
- 'SHORTSUFFIX=emx'#010+
- 'ECHO=echo'#010+
- 'IMPORTLIBPREFIX='#010+
- 'endif'#010+
- #010+
- '# Amiga'#010+
- 'ifeq ($(O','S_TARGET),amiga)'#010+
- 'EXEEXT='#010+
- 'SHAREDLIBEXT=.library'#010+
- 'SHORTSUFFIX=amg'#010+
- 'endif'#010+
- #010+
- '# AROS'#010+
- 'ifeq ($(OS_TARGET),aros)'#010+
- 'EXEEXT='#010+
- 'SHAREDLIBEXT=.library'#010+
- 'SHORTSUFFIX=aros'#010+
- 'endif'#010+
- #010+
- '# MorphOS'#010+
- 'ifeq ($(OS_TARGET),morphos)'#010+
- 'EXEEXT='#010+
- 'SHAREDLIBEXT=.library'#010+
- 'SHORTSUFFIX=mos'#010,
- 'endif'#010+
- #010+
- '# Atari'#010+
- 'ifeq ($(OS_TARGET),atari)'#010+
- 'EXEEXT=.ttp'#010+
- 'SHORTSUFFIX=ata'#010+
- 'endif'#010+
- 'ALL_EXEEXT+=.ttp'#010+
- #010+
- '# BeOS'#010+
- 'ifeq ($(OS_TARGET),beos)'#010+
- 'BATCHEXT=.sh'#010+
- 'EXEEXT='#010+
- 'SHORTSUFFIX=be'#010+
- 'endif'#010+
- #010+
- '# Haiku'#010+
- 'ifeq ($(OS_TARGET),haiku)'#010+
- 'BATCHEXT=.sh'#010+
- 'EXEEXT='#010+
- 'SHORTSUFFIX=hai'#010+
- 'e','ndif'#010+
- #010+
- '# Solaris'#010+
- 'ifeq ($(OS_TARGET),solaris)'#010+
- 'BATCHEXT=.sh'#010+
- 'EXEEXT='#010+
- 'SHORTSUFFIX=sun'#010+
- 'endif'#010+
- #010+
- '# QNX'#010+
- 'ifeq ($(OS_TARGET),qnx)'#010+
- 'BATCHEXT=.sh'#010+
- 'EXEEXT='#010+
- 'SHORTSUFFIX=qnx'#010+
- 'endif'#010+
- #010+
- '# Netware clib'#010+
- 'ifeq ($(OS_TARGET),netware)'#010+
- 'EXEEXT=.nlm'#010+
- 'STATICLIBPREFIX='#010+
- 'SHORTS','UFFIX=nw'#010+
- 'IMPORTLIBPREFIX=imp'#010+
- 'endif'#010+
- 'ALL_EXEEXT+=.nlm'#010+
- #010+
- '# Netware libc'#010+
- 'ifeq ($(OS_TARGET),netwlibc)'#010+
- 'EXEEXT=.nlm'#010+
- 'STATICLIBPREFIX='#010+
- 'SHORTSUFFIX=nwl'#010+
- 'IMPORTLIBPREFIX=imp'#010+
- 'endif'#010+
- #010+
- '# Mac OS Classic'#010+
- 'ifeq ($(OS_TARGET),macosclassic)'#010+
- 'BATCHEXT='#010+
- 'EXEEXT='#010+
- 'DEB','UGSYMEXT=.xcoff'#010+
- 'SHORTSUFFIX=mac'#010+
- 'IMPORTLIBPREFIX=imp'#010+
- 'endif'#010+
- #010+
- '# Darwin'#010+
- 'ifneq ($(filter $(OS_TARGET),darwin iphonesim ios),)'#010+
- 'BATCHEXT=.sh'#010+
- 'EXEEXT='#010+
- 'HASSHAREDLIB=1'#010+
- 'SHORTSUFFIX=dwn'#010+
- 'EXEDBGEXT=.dSYM'#010+
- 'endif'#010+
- #010+
- '# gba'#010+
- 'ifeq ($(OS_TARGET),gba)'#010+
- 'EXEEXT=.gba'#010+
- 'SH','AREDLIBEXT=.so'#010+
- 'SHORTSUFFIX=gba'#010+
- 'endif'#010+
- 'ALL_EXEEXT+=.gba'#010+
- #010+
- '# Symbian OS'#010+
- 'ifeq ($(OS_TARGET),symbian)'#010+
- 'SHAREDLIBEXT=.dll'#010+
- 'SHORTSUFFIX=symbian'#010+
- 'endif'#010+
- #010+
- '# NativeNT'#010+
- 'ifeq ($(OS_TARGET),NativeNT)'#010+
- 'SHAREDLIBEXT=.dll'#010+
- 'SHORTSUFFIX=nativent'#010+
- 'endif'#010+
- #010+
- '# wii'#010+
- 'ifeq ($','(OS_TARGET),wii)'#010+
- 'EXEEXT=.dol'#010+
- 'SHAREDLIBEXT=.so'#010+
- 'SHORTSUFFIX=wii'#010+
- 'endif'#010+
- 'ALL_EXEEXT+=.dol'#010+
- #010+
- '# AIX'#010+
- 'ifeq ($(OS_TARGET),aix)'#010+
- 'BATCHEXT=.sh'#010+
- 'EXEEXT='#010+
- 'SHAREDLIBEXT=.a'#010+
- 'SHORTSUFFIX=aix'#010+
- 'endif'#010+
- #010+
- '# Java'#010+
- 'ifeq ($(OS_TARGET),java)'#010+
- 'OEXT=.class'#010+
- 'ASMEXT=.j'#010+
- 'SHAREDLIBE','XT=.jar'#010+
- 'SHORTSUFFIX=java'#010+
- 'endif'#010+
- #010+
- '# Android java'#010+
- 'ifeq ($(CPU_TARGET),jvm)'#010+
- 'ifeq ($(OS_TARGET),android)'#010+
- 'OEXT=.class'#010+
- 'ASMEXT=.j'#010+
- 'SHAREDLIBEXT=.jar'#010+
- 'SHORTSUFFIX=android'#010+
- 'endif'#010+
- 'endif'#010+
- #010+
- '# MS-DOS'#010+
- 'ifeq ($(OS_TARGET),msdos)'#010+
- 'STATICLIBPREFIX='#010+
- 'STATICLIBEXT=.a',#010+
- 'SHORTSUFFIX=d16'#010+
- 'endif'#010+
- #010+
- '# MSX-DOS'#010+
- 'ifeq ($(OS_TARGET),msxdos)'#010+
- 'STATICLIBPREFIX='#010+
- 'STATICLIBEXT=.a'#010+
- 'SHORTSUFFIX=msd'#010+
- 'endif'#010+
- #010+
- '# Embedded'#010+
- 'ifeq ($(OS_TARGET),embedded)'#010+
- 'ifeq ($(CPU_TARGET),i8086)'#010+
- 'STATICLIBPREFIX='#010+
- 'STATICLIBEXT=.a'#010+
- 'else'#010+
- 'EXEEXT=.bin'#010+
- 'endif'#010,
- 'ifeq ($(CPU_TARGET),z80)'#010+
- 'OEXT=.rel'#010+
- 'endif'#010+
- 'SHORTSUFFIX=emb'#010+
- 'endif'#010+
- 'ALL_EXEEXT+=.bin'#010+
- #010+
- '# Win16'#010+
- 'ifeq ($(OS_TARGET),win16)'#010+
- 'STATICLIBPREFIX='#010+
- 'STATICLIBEXT=.a'#010+
- 'SHAREDLIBEXT=.dll'#010+
- 'SHORTSUFFIX=w16'#010+
- 'endif'#010+
- #010+
- '# ZX Spectrum'#010+
- 'ifeq ($(OS_TARGET),zxspectrum)'#010+
- 'OEXT=.','rel'#010+
- 'endif'#010+
- #010+
- '# WASIp1'#010+
- 'ifeq ($(OS_TARGET),wasip1)'#010+
- 'EXEEXT=.wasm'#010+
- 'endif'#010+
- 'ALL_EXEEXT+=.wasm'#010+
- #010+
- '# WASIp1threads'#010+
- 'ifeq ($(OS_TARGET),wasip1threads)'#010+
- 'EXEEXT=.wasm'#010+
- 'endif'#010+
- #010+
- '# WASIp2'#010+
- 'ifeq ($(OS_TARGET),wasip2)'#010+
- 'EXEEXT=.wasm'#010+
- 'endif'#010+
- #010+
- #010+
- '# For 8.3 limited OS'#039's the s','hort suffixes'#010+
- '# Otherwise use the full source/target names'#010+
- 'ifneq ($(filter $(OS_SOURCE),$(LIMIT83fs)),)'#010+
- 'FPCMADE=fpcmade.$(SHORTSUFFIX)'#010+
- 'ZIPSUFFIX=$(SHORTSUFFIX)'#010+
- 'ZIPCROSSPREFIX='#010+
- 'ZIPSOURCESUFFIX=src'#010+
- 'ZIPEXAMPLESUFFIX=exm'#010+
- 'else'#010+
- 'FPCMADE=fpcmade.$(','TARGETSUFFIX)'#010+
- 'ZIPSOURCESUFFIX=.source'#010+
- 'ZIPEXAMPLESUFFIX=.examples'#010+
- 'ifdef CROSSCOMPILE'#010+
- 'ZIPSUFFIX=.$(SOURCESUFFIX)'#010+
- 'ZIPCROSSPREFIX=$(TARGETSUFFIX)-'#010+
- 'else'#010+
- 'ZIPSUFFIX=.$(TARGETSUFFIX)'#010+
- 'ZIPCROSSPREFIX='#010+
- 'endif'#010+
- 'endif'#010+
- #010+
- '[defaulttools]'#010+
- '#####################','###############################################'+
- '#'#010+
- '# Default Tools'#010+
- '#####################################################################'#010+
- #010+
- '# Names of the binutils tools'#010+
- 'ASNAME=$(BINUTILSPREFIX)as'#010+
- 'LDNAME=$(BINUTILSPREFIX)ld'#010+
- 'ARNAME=$(BINUTILSPRE','FIX)ar'#010+
- 'RCNAME=$(BINUTILSPREFIX)rc'#010+
- 'NASMNAME=$(BINUTILSPREFIX)nasm'#010+
- #010+
- '# assembler, redefine it if cross compiling'#010+
- 'ifndef ASPROG'#010+
- 'ifdef CROSSBINDIR'#010+
- 'ASPROG=$(CROSSBINDIR)/$(ASNAME)$(SRCEXEEXT)'#010+
- 'else'#010+
- 'ASPROG=$(ASNAME)'#010+
- 'endif'#010+
- 'endif'#010+
- #010+
- '# linker, but proba','bly not used'#010+
- 'ifndef LDPROG'#010+
- 'ifdef CROSSBINDIR'#010+
- 'LDPROG=$(CROSSBINDIR)/$(LDNAME)$(SRCEXEEXT)'#010+
- 'else'#010+
- 'LDPROG=$(LDNAME)'#010+
- 'endif'#010+
- 'endif'#010+
- #010+
- '# Resource compiler'#010+
- 'ifndef RCPROG'#010+
- 'ifdef CROSSBINDIR'#010+
- 'RCPROG=$(CROSSBINDIR)/$(RCNAME)$(SRCEXEEXT)'#010+
- 'else'#010+
- 'RCPROG=$(RCNAME',')'#010+
- 'endif'#010+
- 'endif'#010+
- #010+
- '# Archiver'#010+
- 'ifndef ARPROG'#010+
- 'ifdef CROSSBINDIR'#010+
- 'ARPROG=$(CROSSBINDIR)/$(ARNAME)$(SRCEXEEXT)'#010+
- 'else'#010+
- 'ARPROG=$(ARNAME)'#010+
- 'endif'#010+
- 'endif'#010+
- #010+
- '# NASM assembler, redefine it if cross compiling'#010+
- 'ifndef NASMPROG'#010+
- 'ifdef CROSSBINDIR'#010+
- 'NASMPROG=$(CROSSBIND','IR)/$(NASMNAME)$(SRCEXEEXT)'#010+
- 'else'#010+
- 'NASMPROG=$(NASMNAME)'#010+
- 'endif'#010+
- 'endif'#010+
- #010+
- '# Override defaults'#010+
- 'AS=$(ASPROG)'#010+
- 'LD=$(LDPROG)'#010+
- 'RC=$(RCPROG)'#010+
- 'AR=$(ARPROG)'#010+
- 'NASM=$(NASMPROG)'#010+
- #010+
- '# ppas.bat / ppas.sh'#010+
- 'ifdef inUnix'#010+
- 'PPAS=./ppas$(SRCBATCHEXT)'#010+
- 'else'#010+
- 'PPAS=ppas$(SRCBATC','HEXT)'#010+
- 'endif'#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+
- '# Zip options'#010+
- 'ZIPOPT=-9'#010+
- 'ZIPEXT=.zip'#010+
- #010+
- '# Tar options'#010+
- 'ifeq ($(USETAR),bz2)'#010+
- 'TARO','PT=vj'#010+
- 'TAREXT=.tar.bz2'#010+
- 'else'#010+
- 'TAROPT=vz'#010+
- 'TAREXT=.tar.gz'#010+
- 'endif'#010+
- #010+
- #010+
- '[command_begin]'#010+
- '#####################################################################'#010+
- '# Compiler Command Line'#010+
- '#####################################################################'#010,
- #010+
- '# Load commandline OPTDEF and add FPC_CPU define, for compiling the'#010+
- '# compiler this needs to be turned off'#010+
- 'ifndef NOCPUDEF'#010+
- 'override FPCOPTDEF=$(ARCH)'#010+
- 'endif'#010+
- #010+
- #010+
- '# Load commandline OPT and add target and unit dir to be sure'#010+
- 'ifneq ($(OS_TARGET)',',$(OS_SOURCE))'#010+
- 'override FPCOPT+=-T$(OS_TARGET)'#010+
- 'endif'#010+
- #010+
- 'ifneq ($(CPU_TARGET),$(CPU_SOURCE))'#010+
- 'override FPCOPT+=-P$(ARCH)'#010+
- 'endif'#010+
- #010+
- 'ifeq ($(OS_SOURCE),openbsd)'#010+
- 'override FPCOPT+=-FD$(NEW_BINUTILS_PATH)'#010+
- 'override FPCMAKEOPT+=-FD$(NEW_BINUTILS_PATH)'#010+
- 'ov','erride FPMAKE_BUILD_OPT+=-FD$(NEW_BINUTILS_PATH)'#010+
- 'endif'#010+
- #010+
- 'ifndef CROSSBOOTSTRAP'#010+
- 'ifneq ($(BINUTILSPREFIX),)'#010+
- 'override FPCOPT+=-XP$(BINUTILSPREFIX)'#010+
- 'ifneq ($(RLINKPATH),)'#010+
- 'override FPCOPT+=-Xr$(RLINKPATH)'#010+
- 'endif'#010+
- 'endif'#010+
- 'endif'#010+
- #010+
- '# When BINUTILSPREFIX i','s given and we are not cross-compiling then u'+
- 'se'#010+
- '# it while compiling the fpmake file. (For example to build i386-freeb'+
- 'sd'#010+
- '# with BINUTILSPREFIX=i386-)'#010+
- 'ifndef CROSSCOMPILE'#010+
- 'ifneq ($(BINUTILSPREFIX),)'#010+
- 'override FPCMAKEOPT+=-XP$(BINUTILSPREFIX)'#010+
- 'o','verride FPMAKE_BUILD_OPT+=-XP$(BINUTILSPREFIX)'#010+
- 'endif'#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+
- 'e','ndif'#010+
- 'ifdef OBJDIR'#010+
- 'override FPCOPT+=$(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+
- 'overrid','e FPCOPT+=-CX'#010+
- 'endif'#010+
- #010+
- '# Debug'#010+
- 'ifdef DEBUG'#010+
- 'override FPCOPT+=-gl'#010+
- 'override FPCOPTDEF+=DEBUG'#010+
- 'endif'#010+
- #010+
- '# Release mode'#010+
- '# (strip, optimize and don'#039't load fpc.cfg)'#010+
- 'ifdef RELEASE'#010+
- 'FPCCPUOPT:=-O2'#010+
- 'override FPCOPT+=-Ur -Xs $(FPCCPUOPT) -n'#010+
- 'override FPCOPTDE','F+=RELEASE'#010+
- 'endif'#010+
- #010+
- '# Strip'#010+
- 'ifdef STRIP'#010+
- 'override FPCOPT+=-Xs'#010+
- 'endif'#010+
- #010+
- '# Optimizer'#010+
- 'ifdef OPTIMIZE'#010+
- 'override FPCOPT+=-O2'#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 COMP','ILER_OPTIONS'#010+
- 'override FPCOPT+=$(COMPILER_OPTIONS)'#010+
- 'endif'#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 COMPIL','ER_OBJECTDIR'#010+
- 'override FPCOPT+=$(addprefix -Fo,$(COMPILER_OBJECTDIR))'#010+
- 'endif'#010+
- 'ifdef COMPILER_INCLUDEDIR'#010+
- 'override FPCOPT+=$(addprefix -Fi,$(COMPILER_INCLUDEDIR))'#010+
- 'endif'#010+
- #010+
- '# Cross compiler utils'#010+
- 'ifdef CROSSBINDIR'#010+
- 'override FPCOPT+=-FD$(CROSSBINDIR)',#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+
- 'e','ndif'#010+
- 'endif'#010+
- #010+
- '# Unit target dir (default is units/<cpu>-<os>/'#010+
- 'ifdef COMPILER_UNITTARGETDIR'#010+
- 'override FPCOPT+=-FU$(COMPILER_UNITTARGETDIR)'#010+
- 'ifeq ($(COMPILER_UNITTARGETDIR),.)'#010+
- 'override UNITTARGETDIRPREFIX='#010+
- 'else'#010+
- 'override UNITTARGETDIRPREFIX=$(COMP','ILER_UNITTARGETDIR)/'#010+
- 'endif'#010+
- 'else'#010+
- 'ifdef COMPILER_TARGETDIR'#010+
- 'override COMPILER_UNITTARGETDIR=$(COMPILER_TARGETDIR)'#010+
- 'override UNITTARGETDIRPREFIX=$(TARGETDIRPREFIX)'#010+
- 'endif'#010+
- 'endif'#010+
- #010+
- 'ifdef SYSROOTPATH'#010+
- 'override FPCOPT+=-XR$(SYSROOTPATH)'#010+
- 'else'#010+
- '# if we ar','e compiling natively on aarch64-darwin and if -/Library/De'+
- 'veloper/CommandLineTools/SDKs/MacOSX.sdk exists,'#010+
- '# add it to the compiler command line'#010+
- 'ifeq ($(OS_TARGET),$(OS_SOURCE))'#010+
- 'ifeq ($(OS_TARGET),darwin)'#010+
- '# so far the only tested one'#010+
- 'ifeq (','$(CPU_TARGET),aarch64)'#010+
- 'ifneq ($(wildcard /Library/Developer/CommandLineTools/SDKs/MacOSX.sdk)'+
- ',)'#010+
- 'override FPCOPT+=-XR/Library/Developer/CommandLineTools/SDKs/MacOSX.sd'+
- 'k'#010+
- 'endif'#010+
- 'endif'#010+
- 'endif'#010+
- 'endif'#010+
- 'endif'#010+
- #010+
- 'ifdef CREATESHARED'#010+
- 'override FPCOPT+=-Cg'#010+
- 'e','ndif'#010+
- #010+
- '# create always pic'#039'ed code on x86_64, mips and mipsel'#010+
- '# on unix-like systems'#010+
- 'ifneq ($(filter $(OS_TARGET),dragonfly freebsd openbsd netbsd linux so'+
- 'laris),)'#010+
- 'ifneq ($(filter $(CPU_TARGET),x86_64 mips mipsel mips64 mips64el riscv'+
- '64 powe','rpc64),)'#010+
- 'override FPCOPT+=-Cg'#010+
- 'endif'#010+
- 'endif'#010+
- #010+
- '# building without smartlinking on z80 makes no sense'#010+
- 'ifneq ($(filter $(CPU_TARGET),z80),)'#010+
- 'override FPCOPT+=-CX -XX'#010+
- 'endif'#010+
- #010+
- 'ifdef LINKSHARED'#010+
- '#!!! deactived for testing override FPCOPT+=-XD'#010+
- 'endif'#010+
- #010+
- #010+
- '[','command_libc]'#010+
- '# Add GCC lib path if asked'#010+
- 'ifdef GCCLIBDIR'#010+
- 'override FPCOPT+=-Fl$(GCCLIBDIR)'#010+
- 'ifdef FPCMAKEGCCLIBDIR'#010+
- 'override FPCMAKEOPT+=-Fl$(FPCMAKEGCCLIBDIR)'#010+
- 'else'#010+
- 'override FPCMAKEOPT+=-Fl$(GCCLIBDIR)'#010+
- 'endif'#010+
- 'endif'#010+
- 'ifdef OTHERLIBDIR'#010+
- 'override F','PCOPT+=$(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+
- '# Override options to compile the fpmake-binary with command-line opti'+
- 'ons provided in ','FPMAKEBUILDOPT'#010+
- 'ifdef FPMAKEBUILDOPT'#010+
- 'override FPMAKE_BUILD_OPT+=$(FPMAKEBUILDOPT)'#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 CFGFIL','E'#010+
- 'override FPCOPT+=@$(CFGFILE)'#010+
- 'endif'#010+
- #010+
- '# Use the environment to pass commandline options?'#010+
- 'ifdef USEENV'#010+
- 'override FPCEXTCMD:=$(FPCOPT)'#010+
- 'override FPCOPT:=!FPCEXTCMD'#010+
- 'export FPCEXTCMD'#010+
- 'endif'#010+
- #010+
- 'override AFULL_TARGET=$(CPU_TARGET)-$(OS_TARGET)'#010+
- 'overrid','e AFULL_SOURCE=$(CPU_SOURCE)-$(OS_SOURCE)'#010+
- #010+
- 'ifneq ($(AFULL_TARGET),$(AFULL_SOURCE))'#010+
- 'override ACROSSCOMPILE=1'#010+
- 'endif'#010+
- #010+
- 'ifdef ACROSSCOMPILE'#010+
- 'override FPCOPT+=$(CROSSOPT)'#010+
- 'endif'#010+
- #010+
- '# Compiler commandline'#010+
- 'override COMPILER:=$(strip $(FPC) $(FPCOPT))'#010+
- #010,
- '# also call ppas if with command option -s'#010+
- '# but only if the FULL_SOURCE and FULL_TARGET are equal'#010+
- '# or if -sh is used'#010+
- 'ifneq (,$(filter -sh,$(COMPILER)))'#010+
- 'UseEXECPPAS=1'#010+
- 'endif'#010+
- 'ifneq (,$(filter -s,$(COMPILER)))'#010+
- 'ifeq ($(FULL_SOURCE),$(FULL_TARG','ET))'#010+
- 'UseEXECPPAS=1'#010+
- 'endif'#010+
- 'endif'#010+
- 'ifneq ($(UseEXECPPAS),1)'#010+
- 'EXECPPAS='#010+
- 'else'#010+
- 'ifdef RUNBATCH'#010+
- 'EXECPPAS:=@$(RUNBATCH) $(PPAS)'#010+
- 'else'#010+
- 'EXECPPAS:=@$(PPAS)'#010+
- 'endif'#010+
- 'endif'#010+
- #010+
- #010+
- '[loaderrules]'#010+
- '#####################################################################'#010+
- '#',' Loaders'#010+
- '#####################################################################'#010+
- #010+
- '.PHONY: fpc_loaders'#010+
- #010+
- 'ifneq ($(TARGET_LOADERS),)'#010+
- 'override ALLTARGET+=fpc_loaders'#010+
- 'override CLEANTARGET+=fpc_loaders_clean'#010+
- 'override INSTALLTARGET+=fpc_loaders_inst','all'#010+
- #010+
- 'override LOADEROFILES:=$(addsuffix $(OEXT),$(TARGET_LOADERS))'#010+
- 'endif'#010+
- #010+
- '%$(OEXT): %$(LOADEREXT)'#010+
- 'ifdef COMPILER_UNITTARGETDIR'#010+
- ' $(AS) -o $(COMPILER_UNITTARGETDIR)/$*$(OEXT) $<'#010+
- 'else'#010+
- ' $(AS) -o $*$(OEXT) $<'#010+
- 'endif'#010+
- #010+
- 'fpc_loaders: $(','COMPILER_UNITTARGETDIR) $(LOADEROFILES)'#010+
- #010+
- 'fpc_loaders_clean:'#010+
- 'ifdef COMPILER_UNITTARGETDIR'#010+
- ' -$(DEL) $(addprefix $(COMPILER_UNITTARGETDIR)/,$(LOADEROFILES)'+
- ')'#010+
- 'else'#010+
- ' -$(DEL) $(LOADEROFILES)'#010+
- 'endif'#010+
- #010+
- 'fpc_loaders_install:'#010+
- ' $(MKDI','R) $(INSTALL_UNITDIR)'#010+
- 'ifdef COMPILER_UNITTARGETDIR'#010+
- ' $(INSTALL) $(addprefix $(COMPILER_UNITTARGETDIR)/,$(LOADEROFIL'+
- 'ES)) $(INSTALL_UNITDIR)'#010+
- 'else'#010+
- ' $(INSTALL) $(LOADEROFILES) $(INSTALL_UNITDIR)'#010+
- 'endif'#010+
- #010+
- #010+
- '[unitrules]'#010+
- '################','####################################################'+
- '#'#010+
- '# Units'#010+
- '#####################################################################'#010+
- #010+
- '.PHONY: fpc_units'#010+
- #010+
- 'ifneq ($(TARGET_UNITS)$(TARGET_IMPLICITUNITS),)'#010+
- 'override ALLTARGET+=fpc_units'#010+
- #010+
- 'override ','UNITPPUFILES=$(addsuffix $(PPUEXT),$(TARGET_UNITS))'#010+
- 'override IMPLICITUNITPPUFILES=$(addsuffix $(PPUEXT),$(TARGET_IMPLICITU'+
- 'NITS))'#010+
- 'override INSTALLPPUFILES+=$(UNITPPUFILES) $(IMPLICITUNITPPUFILES)'#010+
- 'override CLEANPPUFILES+=$(UNITPPUFILES) $(IMP','LICITUNITPPUFILES)'#010+
- 'endif'#010+
- #010+
- 'fpc_units: $(COMPILER_UNITTARGETDIR) $(UNITPPUFILES)'#010+
- #010+
- #010+
- '[exerules]'#010+
- '#####################################################################'#010+
- '# Exes'#010+
- '#####################################################################'#010+
- #010,
- '.PHONY: fpc_exes'#010+
- #010+
- '# Programs are not needed for a cross installation'#010+
- 'ifndef CROSSINSTALL'#010+
- 'ifneq ($(TARGET_PROGRAMS),)'#010+
- 'override EXEFILES=$(addsuffix $(EXEEXT),$(TARGET_PROGRAMS))'#010+
- 'override ALL_EXEFILES+=$(foreach lEXEEXT,$(ALL_EXEEXT),$(addpre','fix $'+
- '(TARGETDIRPREFIX),$(addsuffix $(lEXEEXT), $(EXEFILES))))'#010+
- 'override EXEOFILES:=$(addsuffix $(OEXT),$(TARGET_PROGRAMS)) $(addsuffi'+
- 'x $(LTOEXT),$(TARGET_PROGRAMS))$(addprefix $(STATICLIBPREFIX),$(addsuf'+
- 'fix $(STATICLIBEXT),$(TARGET_PROGRAMS)',')) $(addprefix $(IMPORTLIBPREF'+
- 'IX),$(addsuffix $(STATICLIBEXT),$(TARGET_PROGRAMS)))'#010+
- 'override EXEDBGFILES:=$(addsuffix $(EXEDBGEXT),$(TARGET_PROGRAMS))'#010+
- #010+
- 'override ALLTARGET+=fpc_exes'#010+
- 'override INSTALLEXEFILES+=$(EXEFILES)'#010+
- 'override CLEANEXEFILES','+=$(EXEFILES) $(EXEOFILES)'#010+
- 'override CLEANEXEDBGFILES+=$(EXEDBGFILES)'#010+
- 'ifeq ($(OS_TARGET),os2)'#010+
- 'override CLEANEXEFILES+=$(addsuffix $(AOUTEXT),$(TARGET_PROGRAMS))'#010+
- 'endif'#010+
- 'ifeq ($(OS_TARGET),emx)'#010+
- 'override CLEANEXEFILES+=$(addsuffix $(AOUTEXT),$(T','ARGET_PROGRAMS))'#010+
- 'endif'#010+
- 'endif'#010+
- 'endif'#010+
- #010+
- 'fpc_exes: $(COMPILER_TARGETDIR) $(COMPILER_UNITTARGETDIR) $(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+
- '[examplerules]'#010+
- '###################################################################','#'+
- '#'#010+
- '# Examples'#010+
- '#####################################################################'#010+
- #010+
- '.PHONY: fpc_examples'#010+
- #010+
- 'ifneq ($(TARGET_EXAMPLES),)'#010+
- 'HASEXAMPLES=1'#010+
- 'override EXAMPLESOURCEFILES=$(wildcard $(addsuffix .pp,$(TARGET_EXAMPL'+
- 'ES)) $(addsuffix .pas',',$(TARGET_EXAMPLES)) $(addsuffix .lpr,$(TARGET_'+
- 'EXAMPLES)) $(addsuffix .dpr,$(TARGET_EXAMPLES)))'#010+
- 'override EXAMPLEFILES:=$(addsuffix $(EXEEXT),$(TARGET_EXAMPLES))'#010+
- 'override EXAMPLEOFILES:=$(addsuffix $(OEXT),$(TARGET_EXAMPLES)) $(adds'+
- 'uffix $(L','TOEXT),$(TARGET_EXAMPLES)) $(addprefix $(STATICLIBPREFIX),$'+
- '(addsuffix $(STATICLIBEXT),$(TARGET_EXAMPLES))) $(addprefix $(IMPORTLI'+
- 'BPREFIX),$(addsuffix $(STATICLIBEXT),$(TARGET_EXAMPLES)))'#010+
- 'override EXAMPLEDBGFILES:=$(addsuffix $(EXEDBGEXT),$(','TARGET_EXAMPLES'+
- '))'#010+
- #010+
- 'override CLEANEXEFILES+=$(EXAMPLEFILES) $(EXAMPLEOFILES)'#010+
- 'override CLEANEXEDBGFILES+=$(EXAMPLEDBGFILES)'#010+
- 'ifeq ($(OS_TARGET),os2)'#010+
- 'override CLEANEXEFILES+=$(addsuffix $(AOUTEXT),$(TARGET_EXAMPLES))'#010+
- 'endif'#010+
- 'ifeq ($(OS_TARGET),em','x)'#010+
- 'override CLEANEXEFILES+=$(addsuffix $(AOUTEXT),$(TARGET_EXAMPLES))'#010+
- 'endif'#010+
- 'endif'#010+
- 'ifneq ($(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_all fpc_smart fpc_debug fpc_release fpc_shared'#010+
- #010+
- '$(FPCMADE): $(ALLDEPENDENCIES)',' $(ALLTARGET)'#010+
- ' @$(ECHOREDIR) Compiled > $(FPCMADE)'#010+
- #010+
- 'fpc_all: $(FPCMADE)'#010+
- #010+
- 'fpc_smart:'#010+
- ' $(MAKE) all LINKSMART=1 CREATESMART=1'#010+
- #010+
- 'fpc_debug:'#010+
- ' $(MAKE) all DEBUG=1'#010+
- #010+
- 'fpc_release:'#010+
- ' $(MAKE) all RELEASE=1'#010+
- #010+
- '# General compile ','rules, available for both possible .pp and .pas ex'+
- 'tensions'#010+
- #010+
- '.SUFFIXES: $(EXEEXT) $(PPUEXT) $(OEXT) $(LTOEXT) .pas .lpr .dpr .pp .r'+
- 'c .res'#010+
- #010+
- '$(COMPILER_UNITTARGETDIR):'#010+
- ' $(MKDIRTREE) $(COMPILER_UNITTARGETDIR)'#010+
- #010+
- '$(COMPILER_TARGETDIR):'#010+
- ' ',' $(MKDIRTREE) $(COMPILER_TARGETDIR)'#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): %.pa','s'#010+
- ' $(COMPILER) $<'#010+
- ' $(EXECPPAS)'#010+
- #010+
- '%$(EXEEXT): %.lpr'#010+
- ' $(COMPILER) $<'#010+
- ' $(EXECPPAS)'#010+
- #010+
- '%$(EXEEXT): %.dpr'#010+
- ' $(COMPILER) $<'#010+
- ' $(EXECPPAS)'#010+
- #010+
- '%.res: %.rc'#010+
- ' windres -i $< -o $@'#010+
- #010+
- '# Search paths for .ppu, .pp,',' .pas, .lpr, .dpr'#010+
- 'vpath %.pp $(COMPILER_SOURCEDIR) $(COMPILER_INCLUDEDIR)'#010+
- 'vpath %.pas $(COMPILER_SOURCEDIR) $(COMPILER_INCLUDEDIR)'#010+
- 'vpath %.lpr $(COMPILER_SOURCEDIR) $(COMPILER_INCLUDEDIR)'#010+
- 'vpath %.dpr $(COMPILER_SOURCEDIR) $(COMPILER_INCLUDE','DIR)'#010+
- 'vpath %.inc $(COMPILER_INCLUDEDIR)'#010+
- 'vpath %$(OEXT) $(COMPILER_UNITTARGETDIR)'#010+
- 'vpath %$(LTOEXT) $(COMPILER_UNITTARGETDIR)'#010+
- 'vpath %$(PPUEXT) $(COMPILER_UNITTARGETDIR)'#010+
- #010+
- '[sharedrules]'#010+
- '##########################################################','##########'+
- '#'#010+
- '# Library'#010+
- '#####################################################################'#010+
- #010+
- '.PHONY: fpc_shared'#010+
- #010+
- 'override INSTALLTARGET+=fpc_shared_install'#010+
- #010+
- 'ifndef SHARED_LIBVERSION'#010+
- 'SHARED_LIBVERSION=$(FPC_VERSION)'#010+
- 'endif'#010+
- #010+
- 'ifndef SHARED_LIBN','AME'#010+
- 'SHARED_LIBNAME=$(PACKAGE_NAME)'#010+
- 'endif'#010+
- #010+
- 'ifndef SHARED_FULLNAME'#010+
- 'SHARED_FULLNAME=$(SHAREDLIBPREFIX)$(SHARED_LIBNAME)-$(SHARED_LIBVERSIO'+
- 'N)$(SHAREDLIBEXT)'#010+
- 'endif'#010+
- #010+
- '# Default sharedlib units are all unit objects'#010+
- 'ifndef SHARED_LIBUNITS'#010+
- 'SHARED_LIB','UNITS:=$(TARGET_UNITS) $(TARGET_IMPLICITUNITS)'#010+
- 'override SHARED_LIBUNITS:=$(filter-out $(INSTALL_BUILDUNIT),$(SHARED_L'+
- 'IBUNITS))'#010+
- 'endif'#010+
- #010+
- 'fpc_shared:'#010+
- 'ifdef HASSHAREDLIB'#010+
- ' $(MAKE) all CREATESHARED=1 LINKSHARED=1 CREATESMART=1'#010+
- 'ifneq ($(SHAR','ED_BUILD),n)'#010+
- ' $(PPUMOVE) -q $(SHARED_LIBUNITS) -i$(COMPILER_UNITTARGETDIR) -'+
- 'o$(SHARED_FULLNAME) -d$(COMPILER_UNITTARGETDIR) -P$(BINUTILSPREFIX)'#010+
- 'endif'#010+
- 'else'#010+
- ' @$(ECHO) Shared Libraries not supported'#010+
- 'endif'#010+
- #010+
- 'fpc_shared_install:'#010+
- 'ifn','eq ($(SHARED_BUILD),n)'#010+
- 'ifneq ($(SHARED_LIBUNITS),)'#010+
- 'ifneq ($(wildcard $(COMPILER_UNITTARGETDIR)/$(SHARED_FULLNAME)),)'#010+
- ' $(INSTALL) $(COMPILER_UNITTARGETDIR)/$(SHARED_FULLNAME) $(INST'+
- 'ALL_SHAREDDIR)'#010+
- 'endif'#010+
- 'endif'#010+
- 'endif'#010+
- #010+
- '[installrules]'#010+
- '####','################################################################'+
- '#'#010+
- '# Install rules'#010+
- '#####################################################################'#010+
- #010+
- '.PHONY: fpc_install fpc_sourceinstall fpc_exampleinstall'#010+
- #010+
- 'ifdef INSTALL_UNITS'#010+
- 'override ','INSTALLPPUFILES+=$(addsuffix $(PPUEXT),$(INSTALL_UNITS))'#010+
- 'endif'#010+
- #010+
- 'ifdef INSTALL_BUILDUNIT'#010+
- 'override INSTALLPPUFILES:=$(filter-out $(INSTALL_BUILDUNIT)$(PPUEXT),$'+
- '(INSTALLPPUFILES))'#010+
- 'endif'#010+
- #010+
- 'ifdef INSTALLPPUFILES'#010+
- '# Avoid getting the same name twic','e as some install EXE fail'#010+
- '# in this case, happends for instance for OS/2 target'#010+
- 'ifneq ($(IMPORTLIBPREFIX)-$(STATICLIBEXT),$(STATICLIBPREFIX)-$(STATICL'+
- 'IBEXT))'#010+
- 'override INSTALLPPULINKFILES:=$(subst $(PPUEXT),$(OEXT),$(INSTALLPPUFI'+
- 'LES)) $(sub','st $(PPUEXT),$(LTOEXT),$(INSTALLPPUFILES)) $(addprefix $('+
- 'STATICLIBPREFIX),$(subst $(PPUEXT),$(STATICLIBEXT),$(INSTALLPPUFILES))'+
- ') $(addprefix $(IMPORTLIBPREFIX),$(subst $(PPUEXT),$(STATICLIBEXT),$(I'+
- 'NSTALLPPUFILES)))'#010+
- 'else'#010+
- 'override INSTALLPPUL','INKFILES:=$(subst $(PPUEXT),$(OEXT),$(INSTALLPPU'+
- 'FILES)) $(subst $(PPUEXT),$(LTOEXT),$(INSTALLPPUFILES)) $(addprefix $('+
- 'STATICLIBPREFIX),$(subst $(PPUEXT),$(STATICLIBEXT),$(INSTALLPPUFILES))'+
- ')'#010+
- 'endif'#010+
- #010+
- 'ifneq ($(UNITTARGETDIRPREFIX),)'#010+
- 'override IN','STALLPPUFILENAMES:=$(notdir $(INSTALLPPUFILES))'#010+
- 'override INSTALLPPULINKFILENAMES:=$(notdir $(INSTALLPPULINKFILES))'#010+
- 'override INSTALLPPUFILES=$(addprefix $(UNITTARGETDIRPREFIX),$(INSTALLP'+
- 'PUFILENAMES))'#010+
- 'override INSTALLPPULINKFILES=$(wildcard $','(addprefix $(UNITTARGETDIRP'+
- 'REFIX),$(INSTALLPPULINKFILENAMES)))'#010+
- 'endif'#010+
- '# Implicitly install Package.fpc'#010+
- 'override INSTALL_CREATEPACKAGEFPC=1'#010+
- 'endif'#010+
- #010+
- 'ifdef INSTALLEXEFILES'#010+
- 'ifneq ($(TARGETDIRPREFIX),)'#010+
- 'override INSTALLEXEFILES:=$(addprefix $(TARGE','TDIRPREFIX),$(notdir $('+
- 'INSTALLEXEFILES)))'#010+
- 'endif'#010+
- 'endif'#010+
- #010+
- 'fpc_install: all $(INSTALLTARGET)'#010+
- 'ifdef INSTALLEXEFILES'#010+
- ' $(MKDIR) $(INSTALL_BINDIR)'#010+
- ' $(INSTALLEXE) $(INSTALLEXEFILES) $(INSTALL_BINDIR)'#010+
- 'endif'#010+
- 'ifdef INSTALL_CREATEPACKAGEFP','C'#010+
- 'ifdef FPCMAKE'#010+
- '# If the fpcpackage variable is set then create and install Package.fp'+
- 'c,'#010+
- '# a safety check is done if Makefile.fpc is available'#010+
- 'ifdef PACKAGE_VERSION'#010+
- 'ifneq ($(wildcard Makefile.fpc),)'#010+
- ' $(FPCMAKE) -p -T$(CPU_TARGET)-$(O','S_TARGET) Makefile.fpc'#010+
- ' $(MKDIR) $(INSTALL_UNITDIR)'#010+
- ' $(INSTALL) Package.fpc $(INSTALL_UNITDIR)'#010+
- 'endif'#010+
- 'endif'#010+
- 'endif'#010+
- 'endif'#010+
- 'ifdef INSTALLPPUFILES'#010+
- ' $(MKDIR) $(INSTALL_UNITDIR)'#010+
- ' $(INSTALL) $(INSTALLPPUFILES) $(INSTALL_U','NITDIR)'#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 in','Unix'#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: distclean'#010+
- ' $','(MKDIR) $(INSTALL_SOURCEDIR)'#010+
- ' $(COPYTREE) $(BASEDIR)/* $(INSTALL_SOURCEDIR)'#010+
- #010+
- 'fpc_exampleinstall: $(EXAMPLEINSTALLTARGET) $(addsuffix _distclean,$(T'+
- 'ARGET_EXAMPLEDIRS))'#010+
- 'ifdef HASEXAMPLES'#010+
- ' $(MKDIR) $(INSTALL_EXAMPLEDIR)'#010+
- 'endif'#010+
- 'ifd','ef EXAMPLESOURCEFILES'#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 deep'#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 ZIPNAM','E'#010+
- 'ifdef DIST_ZIPNAME'#010+
- 'ZIPNAME=$(DIST_ZIPNAME)'#010+
- 'else'#010+
- 'ZIPNAME=$(PACKAGE_NAME)'#010+
- 'endif'#010+
- 'endif'#010+
- #010+
- 'ifndef FULLZIPNAME'#010+
- 'FULLZIPNAME=$(ZIPCROSSPREFIX)$(ZIPPREFIX)$(ZIPNAME)$(ZIPSUFFIX)'#010+
- 'endif'#010+
- #010+
- '# ZipTarget'#010+
- 'ifndef ZIPTARGET'#010+
- 'ifdef DIST_ZIPTARGET'#010+
- 'ZIPTARGET=DIS','T_ZIPTARGET'#010+
- 'else'#010+
- 'ZIPTARGET=install'#010+
- 'endif'#010+
- 'endif'#010+
- #010+
- '# Use tar by default under linux'#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$(SRCBATCHEXT))'#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 /,$(ZIPPATHSEP),$(BASEDIR))'#010+
- 'ifdef USETAR'#010+
- 'ZIPDESTFILE:=$(DIST_DESTDIR)/$(FULLZIPNAME)$(TAREXT)'#010+
- 'ZIPCMD_ZIP:=$(TARPROG) c$(TAROPT)f $(ZIPDESTFILE) *'#010+
- 'else'#010+
- 'ZIPDESTFILE:=$(DIST_DES','TDIR)/$(FULLZIPNAME)$(ZIPEXT)'#010+
- 'ZIPCMD_ZIP:=$(subst /,$(ZIPPATHSEP),$(ZIPPROG)) -Dr $(ZIPOPT) $(ZIPDES'+
- 'TFILE) *'#010+
- 'endif'#010+
- #010+
- 'fpc_zipinstall:'#010+
- ' $(MAKE) $(ZIPTARGET) INSTALL_PREFIX=$(PACKDIR) ZIPINSTALL=1'#010+
- ' $(MKDIR) $(DIST_DESTDIR)'#010+
- ' ',' $(DEL) $(ZIPDESTFILE)'#010+
- 'ifdef USEZIPWRAPPER'#010+
- '# Handle gecho separate as we need to espace \ with \\'#010+
- 'ifneq ($(ECHOREDIR),echo)'#010+
- ' $(ECHOREDIR) -e "$(subst \,\\,$(ZIPCMD_CDPACK))" > $(ZIPWRAPPE'+
- 'R)'#010+
- ' $(ECHOREDIR) -e "$(subst \,\\,$(ZIP','CMD_ZIP))" >> $(ZIPWRAPPE'+
- 'R)'#010+
- ' $(ECHOREDIR) -e "$(subst \,\\,$(ZIPCMD_CDBASE))" >> $(ZIPWRAPP'+
- 'ER)'#010+
- 'else'#010+
- ' echo $(ZIPCMD_CDPACK) > $(ZIPWRAPPER)'#010+
- ' echo $(ZIPCMD_ZIP) >> $(ZIPWRAPPER)'#010+
- ' echo $(ZIPCMD_CDBASE) >> $(ZIPWRAPP','ER)'#010+
- 'endif'#010+
- 'ifdef inUnix'#010+
- ' /bin/sh $(ZIPWRAPPER)'#010+
- 'else'#010+
- 'ifdef RUNBATCH'#010+
- ' $(RUNBATCH) $(ZIPWRAPPER)'#010+
- 'else'#010+
- ' $(ZIPWRAPPER)'#010+
- 'endif'#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=$(ZIP'+
- 'SOURCESUFFIX)'#010+
- #010+
- 'fpc_zipexampleinstall:'#010+
- 'ifdef HASEXAMPLES'#010+
- ' $(MAKE) fpc_zipinstall ZIPTARGET=exampleinstall',' ZIPSUFFIX=$('+
- 'ZIPEXAMPLESUFFIX)'#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+
- 'override CLEANEXEDBGFILES:=$(addprefix $(TARGETDIRPREFIX),$(CLEAN','EXE'+
- 'DBGFILES))'#010+
- 'endif'#010+
- #010+
- 'ifdef CLEAN_PROGRAMS'#010+
- 'override CLEANEXEFILES+=$(addprefix $(TARGETDIRPREFIX),$(addsuffix $(E'+
- 'XEEXT), $(CLEAN_PROGRAMS)))'#010+
- 'override ALL_CLEANEXEFILES+=$(foreach lEXEEXT,$(ALL_EXEEXT),$(addprefi'+
- 'x $(TARGETDIRPREFIX),$(addsuff','ix $(lEXEEXT), $(CLEAN_PROGRAMS))))'#010+
- 'override CLEANEXEDBGFILES+=$(addprefix $(TARGETDIRPREFIX),$(addsuffix '+
- '$(EXEDBGEXT), $(CLEAN_PROGRAMS)))'#010+
- 'endif'#010+
- #010+
- 'ifdef CLEAN_UNITS'#010+
- 'override CLEANPPUFILES+=$(addsuffix $(PPUEXT),$(CLEAN_UNITS))'#010+
- 'endif'#010+
- #010+
- 'ifdef ','CLEANPPUFILES'#010+
- 'override CLEANPPULINKFILES:=$(subst $(PPUEXT),$(OEXT),$(CLEANPPUFILES)'+
- ') $(subst $(PPUEXT),$(LTOEXT),$(CLEANPPUFILES)) $(addprefix $(STATICLI'+
- 'BPREFIX),$(subst $(PPUEXT),$(STATICLIBEXT),$(CLEANPPUFILES))) $(addpre'+
- 'fix $(IMPORTLIBP','REFIX),$(subst $(PPUEXT),$(STATICLIBEXT),$(CLEANPPUF'+
- 'ILES)))'#010+
- 'ifdef DEBUGSYMEXT'#010+
- 'override CLEANPPULINKFILES+=$(subst $(PPUEXT),$(DEBUGSYMEXT),$(CLEANPP'+
- 'UFILES))'#010+
- 'endif'#010+
- 'override CLEANPPUFILENAMES:=$(CLEANPPUFILES)'#010+
- 'override CLEANPPUFILES=$(addpref','ix $(UNITTARGETDIRPREFIX),$(CLEANPPU'+
- 'FILENAMES))'#010+
- 'override CLEANPPULINKFILENAMES:=$(CLEANPPULINKFILES)'#010+
- 'override CLEANPPULINKFILES=$(wildcard $(addprefix $(UNITTARGETDIRPREFI'+
- 'X),$(CLEANPPULINKFILENAMES)))'#010+
- 'endif'#010+
- #010+
- 'fpc_clean: $(CLEANTARGET)'#010+
- 'ifdef ','CLEANEXEFILES'#010+
- ' -$(DEL) $(CLEANEXEFILES)'#010+
- 'endif'#010+
- '# DELTREE instead of DEL because on Mac OS X these are directories'#010+
- 'ifdef CLEANEXEDBGFILES'#010+
- ' -$(DELTREE) $(CLEANEXEDBGFILES)'#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) *$(FULL_TARGET).fpm Package.fpc *$(ASMEXT)'#010+
- ' -$(DEL) $(FPCEXTFILE) $(REDIRFILE) script*.res link*.res *_scr'+
- 'ipt.res *_link.res symbol_order*.fpc'#010+
- ' ',' -$(DEL) $(PPAS) *_ppas$(BATCHEXT) ppas$(BATCHEXT) ppaslink$('+
- 'BATCHEXT)'#010+
- #010+
- 'fpc_cleanall: $(CLEANTARGET)'#010+
- 'ifdef CLEANEXEFILES'#010+
- ' -$(DEL) $(CLEANEXEFILES)'#010+
- 'endif'#010+
- 'ifdef ALL_CLEANEXEFILES'#010+
- ' -$(DEL) $(ALL_CLEANEXEFILES)'#010+
- 'endif'#010+
- 'ifdef COMPILE','R_UNITTARGETDIR'#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+
- 'end','if'#010+
- 'endif'#010+
- 'ifdef CLEAN_FILES'#010+
- ' -$(DEL) $(CLEAN_FILES)'#010+
- 'endif'#010+
- ' -$(DELTREE) units'#010+
- ' -$(DELTREE) bin'#010+
- ' -$(DEL) *$(OEXT) *$(LTOEXT) *$(PPUEXT) *$(RSTEXT) *$(ASMEXT) *'+
- '$(STATICLIBEXT) *$(SHAREDLIBEXT) *$(PPLEXT)'#010+
- 'ifneq ($(PPU','EXT),.ppu)'#010+
- ' -$(DEL) *.o *.ppu *.a'#010+
- 'endif'#010+
- ' -$(DELTREE) *$(SMARTEXT)'#010+
- ' -$(DEL) fpcmade.* Package.fpc *.fpm'#010+
- ' -$(DEL) $(FPCEXTFILE) $(REDIRFILE) script*.res link*.res *_scr'+
- 'ipt.res *_link.res symbol_order*.fpc'#010+
- ' -','$(DEL) $(PPAS) *_ppas$(BATCHEXT) ppas$(BATCHEXT) ppaslink$('+
- 'BATCHEXT)'#010+
- 'ifdef AOUTEXT'#010+
- ' -$(DEL) *$(AOUTEXT)'#010+
- 'endif'#010+
- 'ifdef DEBUGSYMEXT'#010+
- ' -$(DEL) *$(DEBUGSYMEXT)'#010+
- 'endif'#010+
- 'ifdef LOCALFPMAKEBIN'#010+
- ' -$(DEL) $(LOCALFPMAKEBIN)'#010+
- ' -$(D','EL) $(FPMAKEBINOBJ)'#010+
- 'endif'#010+
- #010+
- 'fpc_distclean: cleanall'#010+
- #010+
- #010+
- '[baseinforules]'#010+
- '#####################################################################'#010+
- '# Base info rules'#010+
- '#####################################################################'#010+
- #010+
- '.PHONY: fpc_','baseinfo'#010+
- #010+
- 'override INFORULES+=fpc_baseinfo'#010+
- #010+
- 'fpc_baseinfo:'#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) Full Source.. $(FULL_SOURCE)'#010+
- ' @$(ECHO) Full Target.. $(FULL_TARGET)'#010+
- ' @$(ECHO) SourceSuffix. $(SOURCESUFFIX)'#010+
- ' @$(ECH','O) TargetSuffix. $(TARGETSUFFIX)'#010+
- ' @$(ECHO) FPC fpmake... $(FPCFPMAKE)'#010+
- ' @$(ECHO)'#010+
- ' @$(ECHO) == Directory info =='#010+
- ' @$(ECHO)'#010+
- ' @$(ECHO) Required pkgs... $(REQUIRE_PACKAGES)'#010+
- ' @$(ECHO)'#010+
- ' @$(ECHO)',' Basedir......... $(BASEDIR)'#010+
- ' @$(ECHO) FPCDir.......... $(FPCDIR)'#010+
- ' @$(ECHO) CrossBinDir..... $(CROSSBINDIR)'#010+
- ' @$(ECHO) UnitsDir........ $(UNITSDIR)'#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) As........ $(AS)'#010+
- ' @$(ECHO) Ld........ $(LD)'#010+
- ' ',' @$(ECHO) Ar........ $(AR)'#010+
- ' @$(ECHO) Rc........ $(RC)'#010+
- ' @$(ECHO)'#010+
- ' @$(ECHO) Mv........ $(MVPROG)'#010+
- ' @$(ECHO) Cp........ $(CPPROG)'#010+
- ' @$(ECHO) Rm........ $(RMPROG)'#010+
- ' @$(ECHO) GInstall.. $(GINSTALL)',#010+
- ' @$(ECHO) Echo...... $(ECHO)'#010+
- ' @$(ECHO) Shell..... $(SHELL)'#010+
- ' @$(ECHO) Date...... $(DATE)'#010+
- ' @$(ECHO) FPCMake... $(FPCMAKE)'#010+
- ' @$(ECHO) PPUMove... $(PPUMOVE)'#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 Implicit Units. $(TARGET_IMPLICITUNI','TS)'#010+
- ' @$(ECHO) Target Programs....... $(TARGET_PROGRAMS)'#010+
- ' @$(ECHO) Target Dirs........... $(TARGET_DIRS)'#010+
- ' @$(ECHO) Target Examples....... $(TARGET_EXAMPLES)'#010+
- ' @$(ECHO) Target ExampleDirs.... $(TARGET_EXAMPLEDIR','S)'#010+
- ' @$(ECHO)'#010+
- ' @$(ECHO) Clean Units......... $(CLEAN_UNITS)'#010+
- ' @$(ECHO) Clean Files......... $(CLEAN_FILES)'#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) ZipName.............. $(ZIPNAME)'#010+
- ' @$(ECHO) ZipPrefix............ $(ZIPPREFI','X)'#010+
- ' @$(ECHO) ZipCrossPrefix....... $(ZIPCROSSPREFIX)'#010+
- ' @$(ECHO) ZipSuffix............ $(ZIPSUFFIX)'#010+
- ' @$(ECHO) FullZipName.......... $(FULLZIPNAME)'#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... $(INSTALL_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 destination dir. $(DIST_DESTDIR)'#010+
- ' @$(ECHO) Dist zip name........ $(DIST_ZIPNAME)'#010+
- ' @$(ECHO)'#010+
- #010+
- '[inforules]'#010+
- '#####################################################################'#010+
- '# Info ru','les'#010+
- '#####################################################################'#010+
- #010+
- '.PHONY: fpc_info'#010+
- #010+
- 'fpc_info: $(INFORULES)'#010+
- #010+
- '[makefilerules]'#010+
- '#####################################################################'#010+
- '# Rebuild Makefile'#010+
- '##################','##################################################'+
- '#'#010+
- #010+
- '.PHONY: fpc_makefile fpc_makefiles fpc_makefile_sub1 fpc_makefile_sub2'+
- ' \'#010+
- ' fpc_makefile_dirs'#010+
- #010+
- 'fpc_makefile:'#010+
- ' $(FPCMAKE) -w -T$(OS_TARGET) Makefile.fpc'#010+
- #010+
- 'fpc_makefile_sub1:'#010+
- 'ifd','ef TARGET_DIRS'#010+
- ' $(FPCMAKE) -w -T$(OS_TARGET) $(addsuffix /Makefile.fpc,$(TARGE'+
- 'T_DIRS))'#010+
- 'endif'#010+
- 'ifdef TARGET_EXAMPLEDIRS'#010+
- ' $(FPCMAKE) -w -T$(OS_TARGET) $(addsuffix /Makefile.fpc,$(TARGE'+
- 'T_EXAMPLEDIRS))'#010+
- 'endif'#010+
- #010+
- 'fpc_makefile_sub2: $(a','ddsuffix _makefile_dirs,$(TARGET_DIRS) $(TARGE'+
- 'T_EXAMPLEDIRS))'#010+
- #010+
- 'fpc_makefile_dirs: fpc_makefile_sub1 fpc_makefile_sub2'#010+
- #010+
- 'fpc_makefiles: fpc_makefile fpc_makefile_dirs'#010+
- #010+
- '[localmakefile]'#010+
- '##########################################################','##########'+
- '#'#010+
- '# Local Makefile'#010+
- '#####################################################################'#010+
- #010+
- 'ifneq ($(wildcard fpcmake.loc),)'#010+
- 'include fpcmake.loc'#010+
- 'endif'#010+
- #010+
- #010+
- '[userrules]'#010+
- '###################################################################','#'+
- '#'#010+
- '# Users rules'#010+
- '#####################################################################'#010+
- #010+
- '[lclrules]'#010+
- '#####################################################################'#010+
- '# LCL Rules'#010+
- '###########################################################','#########'+
- '#'#010+
- #010+
- '# LCL Platform'#010+
- 'ifndef LCL_PLATFORM'#010+
- 'ifneq ($(filter $(OS_TARGET),win32 win64),)'#010+
- 'LCL_PLATFORM=win32'#010+
- 'else'#010+
- 'LCL_PLATFORM=gtk'#010+
- 'endif'#010+
- 'endif'#010+
- 'export LCL_PLATFORM'#010+
- #010+
- '# Check if the specified LCLDIR is correct'#010+
- 'ifdef LCLDIR'#010+
- 'override LCLDIR:=$(','subst \,/,$(LCLDIR))'#010+
- 'ifeq ($(wildcard $(LCLDIR)/units/$(LCL_PLATFORM)),)'#010+
- 'override LCLDIR=wrong'#010+
- 'endif'#010+
- 'else'#010+
- 'override LCLDIR=wrong'#010+
- 'endif'#010+
- #010+
- '# Check if the default LCLDIR is correct'#010+
- 'ifdef DEFAULT_LCLDIR'#010+
- 'override LCLDIR:=$(subst \,/,$(DEFAULT_LCLD','IR))'#010+
- 'ifeq ($(wildcard $(LCLDIR)/units/$(LCL_PLATFORM)),)'#010+
- 'override LCLDIR=wrong'#010+
- 'endif'#010+
- 'endif'#010+
- #010+
- '# Check for development version'#010+
- 'ifeq ($(LCLDIR),wrong)'#010+
- 'override LCLDIR=$(subst /units/$(LCL_PLATFORM),,$(firstword $(wildcard'+
- ' $(addsuffix /units/$(L','CL_PLATFORM),$(BASEDIR)/lcl $(BASEDIR)))))'#010+
- 'ifeq ($(LCLDIR),)'#010+
- 'override LCLDIR=wrong'#010+
- 'endif'#010+
- 'endif'#010+
- #010+
- '# Check for release version'#010+
- 'ifeq ($(LCLDIR),wrong)'#010+
- 'override LCLDIR=$(subst /units/$(LCL_PLATFORM),,$(firstword $(wildcard'+
- ' $(addsuffix /lib/lazar','us/units/$(LCL_PLATFORM),/usr/local /usr))))'#010+
- 'ifeq ($(LCLDIR),)'#010+
- 'override LCLDIR=wrong'#010+
- 'endif'#010+
- 'endif'#010+
- #010+
- '# Generate dirs'#010+
- 'override LCLUNITDIR=$(wildcard $(LCLDIR)/units/$(LCL_PLATFORM) $(LCLDI'+
- 'R)/units)'#010+
- 'override LCLCOMPONENTDIR=$(wildcard $(LCLDIR)/','.. $(LCLDIR)/../compon'+
- 'ents $(LCLDIR)/components)'#010+
- 'export LCLDIR LCLUNITDIR LCLCOMPONENTDIR'#010+
- #010+
- '# Add LCL dirs to paths'#010+
- 'override REQUIRE_PACKAGESDIR+=$(LCLCOMPONENTDIR)'#010+
- 'override COMPILER_UNITDIR+=$(LCLUNITDIR)'#010+
- #010+
- '[lclinforules]'#010+
- '###################','#################################################'+
- '#'#010+
- '# LCL Info rules'#010+
- '#####################################################################'#010+
- 'override INFORULES+=lclinfo'#010+
- #010+
- '.PHONY: lclinfo'#010+
- #010+
- 'lclinfo:'#010+
- ' @$(ECHO) == LCL info =='#010+
- ' @$(ECH','O)'#010+
- ' @$(ECHO) Platform............. $(LCL_PLATFORM)'#010+
- ' @$(ECHO) LCLDIR............... $(LCLDIR)'#010+
- ' @$(ECHO) LCL Unit dir......... $(LCLUNITDIR)'#010+
- ' @$(ECHO) LCL Component dir.... $(LCLCOMPONENTDIR)'#010+
- ' @$(ECHO)'#010+
- #010,
- '[fpmakeprerules]'#010+
- '#####################################################################'#010+
- '# fpmake prerules'#010+
- '#####################################################################'#010+
- 'FPMAKEBIN=fpmake$(SRCEXEEXT)'#010+
- 'FPMAKEBINOBJ=fpmake$(OEXT) fpmake$(L','TOEXT)'#010+
- 'LOCALFPMAKEBIN=.$(PATHSEP)$(FPMAKEBIN)'#010+
- #010+
- '# Convert the OS_TARGET and CPU_TARGET options to fpmake'#039's --os an'+
- 'd --cpu parameters'#010+
- 'ifdef OS_TARGET'#010+
- 'FPC_TARGETOPT+=--os=$(OS_TARGET)'#010+
- 'endif'#010+
- 'ifdef CPU_TARGET'#010+
- 'FPC_TARGETOPT+=--cpu=$(CPU_TARGET)'#010+
- 'e','ndif'#010+
- 'ifdef SUB_TARGET'#010+
- 'FPC_TARGETOPT+=--subtarget=$(SUB_TARGET)'#010+
- 'endif'#010+
- #010+
- '# Get the location of the bootstrap-fpmkunit units'#010+
- 'PACKAGEDIR_FPMKUNIT:=$(firstword $(subst /Makefile.fpc,,$(strip $(wild'+
- 'card $(addsuffix /fpmkunit/Makefile.fpc,$(PACKAGE','SDIR))))))'#010+
- 'ifneq ($(PACKAGEDIR_FPMKUNIT),)'#010+
- 'UNITDIR_FPMAKE_FPMKUNIT=$(PACKAGEDIR_FPMKUNIT)/units_bs/$(SOURCESUFFIX'+
- ')'#010+
- 'override COMPILER_FPMAKE_UNITDIR=$(UNITDIR_FPMAKE_FPMKUNIT)'#010+
- 'FPMKUNIT_SRC=$(PACKAGEDIR_FPMKUNIT)/src/fpmkunit.pp'#010+
- 'FPMKUNIT_PPU=','$(UNITDIR_FPMAKE_FPMKUNIT)/fpmkunit.ppu'#010+
- 'endif'#010+
- #010+
- 'ifdef FPMAKE_SKIP_CONFIG'#010+
- 'override FPMAKE_BUILD_OPT+=$(FPMAKE_SKIP_CONFIG)'#010+
- 'endif'#010+
- #010+
- '[fpmakerules]'#010+
- '#####################################################################'#010+
- '# fpmake rules'#010+
- '#############','#######################################################'+
- '#'#010+
- '.PHONY: fpc_fpmake fpc_fpmake_clean fpc_fpmake_install fpc_fpmake_exam'+
- 'pleinstall'#010+
- #010+
- '# Do not pass the Makefile'#039's unit and binary target locations. fpm'+
- 'ake uses it'#039's own.'#010+
- 'override FPCOPT:','=$(filter-out -FU%,$(FPCOPT))'#010+
- 'override FPCOPT:=$(filter-out -FE%,$(FPCOPT))'#010+
- '# Compose general fpmake-parameters'#010+
- 'ifdef FPMAKEOPT'#010+
- 'FPMAKE_OPT+=$(FPMAKEOPT)'#010+
- 'endif'#010+
- 'FPMAKE_OPT+=--localunitdir=$(FPCDIR)'#010+
- 'FPMAKE_OPT+=--globalunitdir=$(FPCDIR)/packag','es'#010+
- 'FPMAKE_OPT+=$(FPC_TARGETOPT)'#010+
- 'FPMAKE_OPT+=$(addprefix -o ,$(FPCOPT))'#010+
- 'FPMAKE_OPT+=--compiler=$(FPC)'#010+
- 'FPMAKE_OPT+=-bu'#010+
- 'ifdef FPC_DOTTEDUNITS'#010+
- 'FPMAKE_OPT+=-ns'#010+
- 'endif'#010+
- #010+
- 'FPMAKE_INSTALL_OPT+=--unitinstalldir=$(INSTALL_UNITDIR)'#010+
- 'ifdef UNIXHier'#010+
- 'FPMAKE_','INSTALL_OPT+=--prefix=$(INSTALL_PREFIX)'#010+
- 'FPMAKE_INSTALL_OPT+=--baseinstalldir=$(INSTALL_LIBDIR)/fpc/$(FPC_VERSI'+
- 'ON)'#010+
- 'else'#010+
- 'FPMAKE_INSTALL_OPT+=--prefix=$(INSTALL_BASEDIR)'#010+
- 'endif'#010+
- #010+
- 'override ALLTARGET+=fpc_fpmake'#010+
- 'override INSTALLTARGET+=fpc_fpmake_','install'#010+
- 'override EXAMPLEINSTALLTARGET+=fpc_fpmake_exampleinstall'#010+
- '# If no fpmake exists and (dist)clean is called, do not try to build f'+
- 'pmake, it will'#010+
- '# most often fail because the dependencies are cleared.'#010+
- '# In case of a clean, simply do no','thing'#010+
- 'ifneq ($(wildcard $(LOCALFPMAKEBIN)),)'#010+
- 'override CLEANTARGET+=fpc_fpmake_clean'#010+
- 'endif'#010+
- #010+
- '$(FPMKUNIT_PPU): $(FPMKUNIT_SRC)'#010+
- ' $(MAKE) -C $(PACKAGEDIR_FPMKUNIT) bootstrap $(addprefix OP'+
- 'T=,$(FPMAKE_BUILD_OPT))'#010+
- #010+
- '$(FPMAKEBIN): fpmake.','pp $(FPMKUNIT_PPU)'#010+
- ' $(FPCFPMAKE) fpmake.pp $(addprefix -Fu,$(COMPILER_FPMAKE_UNITD'+
- 'IR)) $(FPMAKE_BUILD_OPT)'#010+
- #010+
- 'fpc_fpmake: $(FPMAKEBIN)'#010+
- ' $(LOCALFPMAKEBIN) compile $(FPMAKE_OPT)'#010+
- #010+
- 'fpc_fpmake_clean: $(FPMAKEBIN)'#010+
- ' $(LO','CALFPMAKEBIN) clean $(FPMAKE_OPT)'#010+
- #010+
- 'fpc_fpmake_install: $(FPMAKEBIN)'#010+
- ' $(LOCALFPMAKEBIN) install $(FPMAKE_OPT) $(FPMAKE_INSTALL_O'+
- 'PT)'#010+
- #010+
- '# This is not completely valid. Exampleinstall should only install the'+
- ' examples, while'#010+
- '# fpmake -','ie installs everything, including the examples. This also '+
- 'means that on'#010+
- '# a distinstall fpmake install wil be called twice.'#010+
- 'fpc_fpmake_exampleinstall: $(FPMAKEBIN)'#010+
- ' $(LOCALFPMAKEBIN) install -ie $(FPMAKE_OPT) $(FPMAKE_INSTA'+
- 'LL_OPT',')'#010
- );
|