diff options
author | michael <michael@3ad0048d-3df7-0310-abae-a5850022a9f2> | 2008-01-09 20:57:26 +0000 |
---|---|---|
committer | michael <michael@3ad0048d-3df7-0310-abae-a5850022a9f2> | 2008-01-09 20:57:26 +0000 |
commit | 8375107ddfb0ded9f9e21f191478548fbcc918cc (patch) | |
tree | 94021ee6e6e0846ff3a639f245af39c4b64cff8e | |
parent | bb933d51cc8adb6e8d360118866778bb115adabb (diff) | |
download | fpc-8375107ddfb0ded9f9e21f191478548fbcc918cc.tar.gz |
* New tool from Giulio Bernardi
git-svn-id: http://svn.freepascal.org/svn/fpc/branches/resources@9699 3ad0048d-3df7-0310-abae-a5850022a9f2
-rw-r--r-- | utils/fpcreslipo/Makefile | 2256 | ||||
-rw-r--r-- | utils/fpcreslipo/Makefile.fpc | 21 | ||||
-rw-r--r-- | utils/fpcreslipo/fpcreslipo.pp | 271 | ||||
-rw-r--r-- | utils/fpcreslipo/msghandler.pp | 105 | ||||
-rw-r--r-- | utils/fpcreslipo/paramparser.pp | 187 | ||||
-rw-r--r-- | utils/fpcreslipo/sourcehandler.pp | 341 |
6 files changed, 3181 insertions, 0 deletions
diff --git a/utils/fpcreslipo/Makefile b/utils/fpcreslipo/Makefile new file mode 100644 index 0000000000..77bfd89e83 --- /dev/null +++ b/utils/fpcreslipo/Makefile @@ -0,0 +1,2256 @@ +# +# Don't edit, this file is generated by FPCMake Version 2.0.0 [2007/11/14] +# +default: all +MAKEFILETARGETS=i386-linux i386-go32v2 i386-win32 i386-os2 i386-freebsd i386-beos i386-netbsd i386-solaris i386-qnx i386-netware i386-openbsd i386-wdosx i386-darwin i386-emx i386-watcom i386-netwlibc i386-wince i386-embedded i386-symbian m68k-linux m68k-freebsd m68k-netbsd m68k-amiga m68k-atari m68k-openbsd m68k-palmos m68k-embedded powerpc-linux powerpc-netbsd powerpc-amiga powerpc-macos powerpc-darwin powerpc-morphos powerpc-embedded sparc-linux sparc-netbsd sparc-solaris sparc-embedded x86_64-linux x86_64-freebsd x86_64-darwin x86_64-win64 x86_64-embedded arm-linux arm-palmos arm-wince arm-gba arm-nds arm-embedded arm-symbian powerpc64-linux powerpc64-darwin powerpc64-embedded +BSDs = freebsd netbsd openbsd darwin +UNIXs = linux $(BSDs) solaris qnx +LIMIT83fs = go32v2 os2 emx watcom +OSNeedsComspecToRunBatch = go32v2 watcom +FORCE: +.PHONY: FORCE +override PATH:=$(patsubst %/,%,$(subst \,/,$(PATH))) +ifneq ($(findstring darwin,$(OSTYPE)),) +inUnix=1 #darwin +SEARCHPATH:=$(filter-out .,$(subst :, ,$(PATH))) +else +ifeq ($(findstring ;,$(PATH)),) +inUnix=1 +SEARCHPATH:=$(filter-out .,$(subst :, ,$(PATH))) +else +SEARCHPATH:=$(subst ;, ,$(PATH)) +endif +endif +SEARCHPATH+=$(patsubst %/,%,$(subst \,/,$(dir $(MAKE)))) +PWD:=$(strip $(wildcard $(addsuffix /pwd.exe,$(SEARCHPATH)))) +ifeq ($(PWD),) +PWD:=$(strip $(wildcard $(addsuffix /pwd,$(SEARCHPATH)))) +ifeq ($(PWD),) +$(error You need the GNU utils package to use this Makefile) +else +PWD:=$(firstword $(PWD)) +SRCEXEEXT= +endif +else +PWD:=$(firstword $(PWD)) +SRCEXEEXT=.exe +endif +ifndef inUnix +ifeq ($(OS),Windows_NT) +inWinNT=1 +else +ifdef OS2_SHELL +inOS2=1 +endif +endif +else +ifneq ($(findstring cygdrive,$(PATH)),) +inCygWin=1 +endif +endif +ifdef inUnix +SRCBATCHEXT=.sh +else +ifdef inOS2 +SRCBATCHEXT=.cmd +else +SRCBATCHEXT=.bat +endif +endif +ifdef COMSPEC +ifneq ($(findstring $(OS_SOURCE),$(OSNeedsComspecToRunBatch)),) +RUNBATCH=$(COMSPEC) /C +endif +endif +ifdef inUnix +PATHSEP=/ +else +PATHSEP:=$(subst /,\,/) +ifdef inCygWin +PATHSEP=/ +endif +endif +ifdef PWD +BASEDIR:=$(subst \,/,$(shell $(PWD))) +ifdef inCygWin +ifneq ($(findstring /cygdrive/,$(BASEDIR)),) +BASENODIR:=$(patsubst /cygdrive%,%,$(BASEDIR)) +BASEDRIVE:=$(firstword $(subst /, ,$(BASENODIR))) +BASEDIR:=$(subst /cygdrive/$(BASEDRIVE)/,$(BASEDRIVE):/,$(BASEDIR)) +endif +endif +else +BASEDIR=. +endif +ifdef inOS2 +ifndef ECHO +ECHO:=$(strip $(wildcard $(addsuffix /gecho$(SRCEXEEXT),$(SEARCHPATH)))) +ifeq ($(ECHO),) +ECHO:=$(strip $(wildcard $(addsuffix /echo$(SRCEXEEXT),$(SEARCHPATH)))) +ifeq ($(ECHO),) +ECHO=echo +else +ECHO:=$(firstword $(ECHO)) +endif +else +ECHO:=$(firstword $(ECHO)) +endif +endif +export ECHO +endif +override DEFAULT_FPCDIR=../.. +ifndef FPC +ifdef PP +FPC=$(PP) +endif +endif +ifndef FPC +FPCPROG:=$(strip $(wildcard $(addsuffix /fpc$(SRCEXEEXT),$(SEARCHPATH)))) +ifneq ($(FPCPROG),) +FPCPROG:=$(firstword $(FPCPROG)) +ifneq ($(CPU_TARGET),) +FPC:=$(shell $(FPCPROG) -P$(CPU_TARGET) -PB) +else +FPC:=$(shell $(FPCPROG) -PB) +endif +ifneq ($(findstring Error,$(FPC)),) +override FPC=$(firstword $(strip $(wildcard $(addsuffix /ppc386$(SRCEXEEXT),$(SEARCHPATH))))) +endif +else +override FPC=$(firstword $(strip $(wildcard $(addsuffix /ppc386$(SRCEXEEXT),$(SEARCHPATH))))) +endif +endif +override FPC:=$(subst $(SRCEXEEXT),,$(FPC)) +override FPC:=$(subst \,/,$(FPC))$(SRCEXEEXT) +FOUNDFPC:=$(strip $(wildcard $(FPC))) +ifeq ($(FOUNDFPC),) +FOUNDFPC=$(strip $(wildcard $(addsuffix /$(FPC),$(SEARCHPATH)))) +ifeq ($(FOUNDFPC),) +$(error Compiler $(FPC) not found) +endif +endif +ifndef FPC_COMPILERINFO +FPC_COMPILERINFO:=$(shell $(FPC) -iVSPTPSOTO) +endif +ifndef FPC_VERSION +FPC_VERSION:=$(word 1,$(FPC_COMPILERINFO)) +endif +export FPC FPC_VERSION FPC_COMPILERINFO +unexport CHECKDEPEND ALLDEPENDENCIES +ifndef CPU_TARGET +ifdef CPU_TARGET_DEFAULT +CPU_TARGET=$(CPU_TARGET_DEFAULT) +endif +endif +ifndef OS_TARGET +ifdef OS_TARGET_DEFAULT +OS_TARGET=$(OS_TARGET_DEFAULT) +endif +endif +ifneq ($(words $(FPC_COMPILERINFO)),5) +FPC_COMPILERINFO+=$(shell $(FPC) -iSP) +FPC_COMPILERINFO+=$(shell $(FPC) -iTP) +FPC_COMPILERINFO+=$(shell $(FPC) -iSO) +FPC_COMPILERINFO+=$(shell $(FPC) -iTO) +endif +ifndef CPU_SOURCE +CPU_SOURCE:=$(word 2,$(FPC_COMPILERINFO)) +endif +ifndef CPU_TARGET +CPU_TARGET:=$(word 3,$(FPC_COMPILERINFO)) +endif +ifndef OS_SOURCE +OS_SOURCE:=$(word 4,$(FPC_COMPILERINFO)) +endif +ifndef OS_TARGET +OS_TARGET:=$(word 5,$(FPC_COMPILERINFO)) +endif +FULL_TARGET=$(CPU_TARGET)-$(OS_TARGET) +FULL_SOURCE=$(CPU_SOURCE)-$(OS_SOURCE) +ifneq ($(findstring $(OS_SOURCE),$(LIMIT83fs)),) +TARGETSUFFIX=$(OS_TARGET) +SOURCESUFFIX=$(OS_SOURCE) +else +TARGETSUFFIX=$(FULL_TARGET) +SOURCESUFFIX=$(FULL_SOURCE) +endif +ifneq ($(FULL_TARGET),$(FULL_SOURCE)) +CROSSCOMPILE=1 +endif +ifeq ($(findstring makefile,$(MAKECMDGOALS)),) +ifeq ($(findstring $(FULL_TARGET),$(MAKEFILETARGETS)),) +$(error The Makefile doesn't support target $(FULL_TARGET), please run fpcmake first) +endif +endif +ifneq ($(findstring $(OS_TARGET),$(BSDs)),) +BSDhier=1 +endif +ifeq ($(OS_TARGET),linux) +linuxHier=1 +endif +export OS_TARGET OS_SOURCE CPU_TARGET CPU_SOURCE FULL_TARGET FULL_SOURCE TARGETSUFFIX SOURCESUFFIX CROSSCOMPILE +ifdef FPCDIR +override FPCDIR:=$(subst \,/,$(FPCDIR)) +ifeq ($(wildcard $(addprefix $(FPCDIR)/,rtl units)),) +override FPCDIR=wrong +endif +else +override FPCDIR=wrong +endif +ifdef DEFAULT_FPCDIR +ifeq ($(FPCDIR),wrong) +override FPCDIR:=$(subst \,/,$(DEFAULT_FPCDIR)) +ifeq ($(wildcard $(addprefix $(FPCDIR)/,rtl units)),) +override FPCDIR=wrong +endif +endif +endif +ifeq ($(FPCDIR),wrong) +ifdef inUnix +override FPCDIR=/usr/local/lib/fpc/$(FPC_VERSION) +ifeq ($(wildcard $(FPCDIR)/units),) +override FPCDIR=/usr/lib/fpc/$(FPC_VERSION) +endif +else +override FPCDIR:=$(subst /$(FPC),,$(firstword $(strip $(wildcard $(addsuffix /$(FPC),$(SEARCHPATH)))))) +override FPCDIR:=$(FPCDIR)/.. +ifeq ($(wildcard $(addprefix $(FPCDIR)/,rtl units)),) +override FPCDIR:=$(FPCDIR)/.. +ifeq ($(wildcard $(addprefix $(FPCDIR)/,rtl units)),) +override FPCDIR:=$(BASEDIR) +ifeq ($(wildcard $(addprefix $(FPCDIR)/,rtl units)),) +override FPCDIR=c:/pp +endif +endif +endif +endif +endif +ifndef CROSSBINDIR +CROSSBINDIR:=$(wildcard $(FPCDIR)/bin/$(TARGETSUFFIX)) +endif +ifndef BINUTILSPREFIX +ifndef CROSSBINDIR +ifdef CROSSCOMPILE +BINUTILSPREFIX=$(CPU_TARGET)-$(OS_TARGET)- +endif +endif +endif +UNITSDIR:=$(wildcard $(FPCDIR)/units/$(TARGETSUFFIX)) +ifeq ($(UNITSDIR),) +UNITSDIR:=$(wildcard $(FPCDIR)/units/$(OS_TARGET)) +endif +PACKAGESDIR:=$(wildcard $(FPCDIR) $(FPCDIR)/packages $(FPCDIR)/packages/base $(FPCDIR)/packages/extra) +ifeq ($(FULL_TARGET),i386-linux) +override TARGET_PROGRAMS+=fpcreslipo +endif +ifeq ($(FULL_TARGET),i386-go32v2) +override TARGET_PROGRAMS+=fpcreslipo +endif +ifeq ($(FULL_TARGET),i386-win32) +override TARGET_PROGRAMS+=fpcreslipo +endif +ifeq ($(FULL_TARGET),i386-os2) +override TARGET_PROGRAMS+=fpcreslipo +endif +ifeq ($(FULL_TARGET),i386-freebsd) +override TARGET_PROGRAMS+=fpcreslipo +endif +ifeq ($(FULL_TARGET),i386-beos) +override TARGET_PROGRAMS+=fpcreslipo +endif +ifeq ($(FULL_TARGET),i386-netbsd) +override TARGET_PROGRAMS+=fpcreslipo +endif +ifeq ($(FULL_TARGET),i386-solaris) +override TARGET_PROGRAMS+=fpcreslipo +endif +ifeq ($(FULL_TARGET),i386-qnx) +override TARGET_PROGRAMS+=fpcreslipo +endif +ifeq ($(FULL_TARGET),i386-netware) +override TARGET_PROGRAMS+=fpcreslipo +endif +ifeq ($(FULL_TARGET),i386-openbsd) +override TARGET_PROGRAMS+=fpcreslipo +endif +ifeq ($(FULL_TARGET),i386-wdosx) +override TARGET_PROGRAMS+=fpcreslipo +endif +ifeq ($(FULL_TARGET),i386-darwin) +override TARGET_PROGRAMS+=fpcreslipo +endif +ifeq ($(FULL_TARGET),i386-emx) +override TARGET_PROGRAMS+=fpcreslipo +endif +ifeq ($(FULL_TARGET),i386-watcom) +override TARGET_PROGRAMS+=fpcreslipo +endif +ifeq ($(FULL_TARGET),i386-netwlibc) +override TARGET_PROGRAMS+=fpcreslipo +endif +ifeq ($(FULL_TARGET),i386-wince) +override TARGET_PROGRAMS+=fpcreslipo +endif +ifeq ($(FULL_TARGET),i386-embedded) +override TARGET_PROGRAMS+=fpcreslipo +endif +ifeq ($(FULL_TARGET),i386-symbian) +override TARGET_PROGRAMS+=fpcreslipo +endif +ifeq ($(FULL_TARGET),m68k-linux) +override TARGET_PROGRAMS+=fpcreslipo +endif +ifeq ($(FULL_TARGET),m68k-freebsd) +override TARGET_PROGRAMS+=fpcreslipo +endif +ifeq ($(FULL_TARGET),m68k-netbsd) +override TARGET_PROGRAMS+=fpcreslipo +endif +ifeq ($(FULL_TARGET),m68k-amiga) +override TARGET_PROGRAMS+=fpcreslipo +endif +ifeq ($(FULL_TARGET),m68k-atari) +override TARGET_PROGRAMS+=fpcreslipo +endif +ifeq ($(FULL_TARGET),m68k-openbsd) +override TARGET_PROGRAMS+=fpcreslipo +endif +ifeq ($(FULL_TARGET),m68k-palmos) +override TARGET_PROGRAMS+=fpcreslipo +endif +ifeq ($(FULL_TARGET),m68k-embedded) +override TARGET_PROGRAMS+=fpcreslipo +endif +ifeq ($(FULL_TARGET),powerpc-linux) +override TARGET_PROGRAMS+=fpcreslipo +endif +ifeq ($(FULL_TARGET),powerpc-netbsd) +override TARGET_PROGRAMS+=fpcreslipo +endif +ifeq ($(FULL_TARGET),powerpc-amiga) +override TARGET_PROGRAMS+=fpcreslipo +endif +ifeq ($(FULL_TARGET),powerpc-macos) +override TARGET_PROGRAMS+=fpcreslipo +endif +ifeq ($(FULL_TARGET),powerpc-darwin) +override TARGET_PROGRAMS+=fpcreslipo +endif +ifeq ($(FULL_TARGET),powerpc-morphos) +override TARGET_PROGRAMS+=fpcreslipo +endif +ifeq ($(FULL_TARGET),powerpc-embedded) +override TARGET_PROGRAMS+=fpcreslipo +endif +ifeq ($(FULL_TARGET),sparc-linux) +override TARGET_PROGRAMS+=fpcreslipo +endif +ifeq ($(FULL_TARGET),sparc-netbsd) +override TARGET_PROGRAMS+=fpcreslipo +endif +ifeq ($(FULL_TARGET),sparc-solaris) +override TARGET_PROGRAMS+=fpcreslipo +endif +ifeq ($(FULL_TARGET),sparc-embedded) +override TARGET_PROGRAMS+=fpcreslipo +endif +ifeq ($(FULL_TARGET),x86_64-linux) +override TARGET_PROGRAMS+=fpcreslipo +endif +ifeq ($(FULL_TARGET),x86_64-freebsd) +override TARGET_PROGRAMS+=fpcreslipo +endif +ifeq ($(FULL_TARGET),x86_64-darwin) +override TARGET_PROGRAMS+=fpcreslipo +endif +ifeq ($(FULL_TARGET),x86_64-win64) +override TARGET_PROGRAMS+=fpcreslipo +endif +ifeq ($(FULL_TARGET),x86_64-embedded) +override TARGET_PROGRAMS+=fpcreslipo +endif +ifeq ($(FULL_TARGET),arm-linux) +override TARGET_PROGRAMS+=fpcreslipo +endif +ifeq ($(FULL_TARGET),arm-palmos) +override TARGET_PROGRAMS+=fpcreslipo +endif +ifeq ($(FULL_TARGET),arm-wince) +override TARGET_PROGRAMS+=fpcreslipo +endif +ifeq ($(FULL_TARGET),arm-gba) +override TARGET_PROGRAMS+=fpcreslipo +endif +ifeq ($(FULL_TARGET),arm-nds) +override TARGET_PROGRAMS+=fpcreslipo +endif +ifeq ($(FULL_TARGET),arm-embedded) +override TARGET_PROGRAMS+=fpcreslipo +endif +ifeq ($(FULL_TARGET),arm-symbian) +override TARGET_PROGRAMS+=fpcreslipo +endif +ifeq ($(FULL_TARGET),powerpc64-linux) +override TARGET_PROGRAMS+=fpcreslipo +endif +ifeq ($(FULL_TARGET),powerpc64-darwin) +override TARGET_PROGRAMS+=fpcreslipo +endif +ifeq ($(FULL_TARGET),powerpc64-embedded) +override TARGET_PROGRAMS+=fpcreslipo +endif +ifeq ($(FULL_TARGET),i386-linux) +override TARGET_UNITS+=msghandler paramparser sourcehandler +endif +ifeq ($(FULL_TARGET),i386-go32v2) +override TARGET_UNITS+=msghandler paramparser sourcehandler +endif +ifeq ($(FULL_TARGET),i386-win32) +override TARGET_UNITS+=msghandler paramparser sourcehandler +endif +ifeq ($(FULL_TARGET),i386-os2) +override TARGET_UNITS+=msghandler paramparser sourcehandler +endif +ifeq ($(FULL_TARGET),i386-freebsd) +override TARGET_UNITS+=msghandler paramparser sourcehandler +endif +ifeq ($(FULL_TARGET),i386-beos) +override TARGET_UNITS+=msghandler paramparser sourcehandler +endif +ifeq ($(FULL_TARGET),i386-netbsd) +override TARGET_UNITS+=msghandler paramparser sourcehandler +endif +ifeq ($(FULL_TARGET),i386-solaris) +override TARGET_UNITS+=msghandler paramparser sourcehandler +endif +ifeq ($(FULL_TARGET),i386-qnx) +override TARGET_UNITS+=msghandler paramparser sourcehandler +endif +ifeq ($(FULL_TARGET),i386-netware) +override TARGET_UNITS+=msghandler paramparser sourcehandler +endif +ifeq ($(FULL_TARGET),i386-openbsd) +override TARGET_UNITS+=msghandler paramparser sourcehandler +endif +ifeq ($(FULL_TARGET),i386-wdosx) +override TARGET_UNITS+=msghandler paramparser sourcehandler +endif +ifeq ($(FULL_TARGET),i386-darwin) +override TARGET_UNITS+=msghandler paramparser sourcehandler +endif +ifeq ($(FULL_TARGET),i386-emx) +override TARGET_UNITS+=msghandler paramparser sourcehandler +endif +ifeq ($(FULL_TARGET),i386-watcom) +override TARGET_UNITS+=msghandler paramparser sourcehandler +endif +ifeq ($(FULL_TARGET),i386-netwlibc) +override TARGET_UNITS+=msghandler paramparser sourcehandler +endif +ifeq ($(FULL_TARGET),i386-wince) +override TARGET_UNITS+=msghandler paramparser sourcehandler +endif +ifeq ($(FULL_TARGET),i386-embedded) +override TARGET_UNITS+=msghandler paramparser sourcehandler +endif +ifeq ($(FULL_TARGET),i386-symbian) +override TARGET_UNITS+=msghandler paramparser sourcehandler +endif +ifeq ($(FULL_TARGET),m68k-linux) +override TARGET_UNITS+=msghandler paramparser sourcehandler +endif +ifeq ($(FULL_TARGET),m68k-freebsd) +override TARGET_UNITS+=msghandler paramparser sourcehandler +endif +ifeq ($(FULL_TARGET),m68k-netbsd) +override TARGET_UNITS+=msghandler paramparser sourcehandler +endif +ifeq ($(FULL_TARGET),m68k-amiga) +override TARGET_UNITS+=msghandler paramparser sourcehandler +endif +ifeq ($(FULL_TARGET),m68k-atari) +override TARGET_UNITS+=msghandler paramparser sourcehandler +endif +ifeq ($(FULL_TARGET),m68k-openbsd) +override TARGET_UNITS+=msghandler paramparser sourcehandler +endif +ifeq ($(FULL_TARGET),m68k-palmos) +override TARGET_UNITS+=msghandler paramparser sourcehandler +endif +ifeq ($(FULL_TARGET),m68k-embedded) +override TARGET_UNITS+=msghandler paramparser sourcehandler +endif +ifeq ($(FULL_TARGET),powerpc-linux) +override TARGET_UNITS+=msghandler paramparser sourcehandler +endif +ifeq ($(FULL_TARGET),powerpc-netbsd) +override TARGET_UNITS+=msghandler paramparser sourcehandler +endif +ifeq ($(FULL_TARGET),powerpc-amiga) +override TARGET_UNITS+=msghandler paramparser sourcehandler +endif +ifeq ($(FULL_TARGET),powerpc-macos) +override TARGET_UNITS+=msghandler paramparser sourcehandler +endif +ifeq ($(FULL_TARGET),powerpc-darwin) +override TARGET_UNITS+=msghandler paramparser sourcehandler +endif +ifeq ($(FULL_TARGET),powerpc-morphos) +override TARGET_UNITS+=msghandler paramparser sourcehandler +endif +ifeq ($(FULL_TARGET),powerpc-embedded) +override TARGET_UNITS+=msghandler paramparser sourcehandler +endif +ifeq ($(FULL_TARGET),sparc-linux) +override TARGET_UNITS+=msghandler paramparser sourcehandler +endif +ifeq ($(FULL_TARGET),sparc-netbsd) +override TARGET_UNITS+=msghandler paramparser sourcehandler +endif +ifeq ($(FULL_TARGET),sparc-solaris) +override TARGET_UNITS+=msghandler paramparser sourcehandler +endif +ifeq ($(FULL_TARGET),sparc-embedded) +override TARGET_UNITS+=msghandler paramparser sourcehandler +endif +ifeq ($(FULL_TARGET),x86_64-linux) +override TARGET_UNITS+=msghandler paramparser sourcehandler +endif +ifeq ($(FULL_TARGET),x86_64-freebsd) +override TARGET_UNITS+=msghandler paramparser sourcehandler +endif +ifeq ($(FULL_TARGET),x86_64-darwin) +override TARGET_UNITS+=msghandler paramparser sourcehandler +endif +ifeq ($(FULL_TARGET),x86_64-win64) +override TARGET_UNITS+=msghandler paramparser sourcehandler +endif +ifeq ($(FULL_TARGET),x86_64-embedded) +override TARGET_UNITS+=msghandler paramparser sourcehandler +endif +ifeq ($(FULL_TARGET),arm-linux) +override TARGET_UNITS+=msghandler paramparser sourcehandler +endif +ifeq ($(FULL_TARGET),arm-palmos) +override TARGET_UNITS+=msghandler paramparser sourcehandler +endif +ifeq ($(FULL_TARGET),arm-wince) +override TARGET_UNITS+=msghandler paramparser sourcehandler +endif +ifeq ($(FULL_TARGET),arm-gba) +override TARGET_UNITS+=msghandler paramparser sourcehandler +endif +ifeq ($(FULL_TARGET),arm-nds) +override TARGET_UNITS+=msghandler paramparser sourcehandler +endif +ifeq ($(FULL_TARGET),arm-embedded) +override TARGET_UNITS+=msghandler paramparser sourcehandler +endif +ifeq ($(FULL_TARGET),arm-symbian) +override TARGET_UNITS+=msghandler paramparser sourcehandler +endif +ifeq ($(FULL_TARGET),powerpc64-linux) +override TARGET_UNITS+=msghandler paramparser sourcehandler +endif +ifeq ($(FULL_TARGET),powerpc64-darwin) +override TARGET_UNITS+=msghandler paramparser sourcehandler +endif +ifeq ($(FULL_TARGET),powerpc64-embedded) +override TARGET_UNITS+=msghandler paramparser sourcehandler +endif +ifeq ($(FULL_TARGET),i386-linux) +override CLEAN_UNITS+=fpcresfix elfbfd elfres +endif +ifeq ($(FULL_TARGET),i386-go32v2) +override CLEAN_UNITS+=fpcresfix elfbfd elfres +endif +ifeq ($(FULL_TARGET),i386-win32) +override CLEAN_UNITS+=fpcresfix elfbfd elfres +endif +ifeq ($(FULL_TARGET),i386-os2) +override CLEAN_UNITS+=fpcresfix elfbfd elfres +endif +ifeq ($(FULL_TARGET),i386-freebsd) +override CLEAN_UNITS+=fpcresfix elfbfd elfres +endif +ifeq ($(FULL_TARGET),i386-beos) +override CLEAN_UNITS+=fpcresfix elfbfd elfres +endif +ifeq ($(FULL_TARGET),i386-netbsd) +override CLEAN_UNITS+=fpcresfix elfbfd elfres +endif +ifeq ($(FULL_TARGET),i386-solaris) +override CLEAN_UNITS+=fpcresfix elfbfd elfres +endif +ifeq ($(FULL_TARGET),i386-qnx) +override CLEAN_UNITS+=fpcresfix elfbfd elfres +endif +ifeq ($(FULL_TARGET),i386-netware) +override CLEAN_UNITS+=fpcresfix elfbfd elfres +endif +ifeq ($(FULL_TARGET),i386-openbsd) +override CLEAN_UNITS+=fpcresfix elfbfd elfres +endif +ifeq ($(FULL_TARGET),i386-wdosx) +override CLEAN_UNITS+=fpcresfix elfbfd elfres +endif +ifeq ($(FULL_TARGET),i386-darwin) +override CLEAN_UNITS+=fpcresfix elfbfd elfres +endif +ifeq ($(FULL_TARGET),i386-emx) +override CLEAN_UNITS+=fpcresfix elfbfd elfres +endif +ifeq ($(FULL_TARGET),i386-watcom) +override CLEAN_UNITS+=fpcresfix elfbfd elfres +endif +ifeq ($(FULL_TARGET),i386-netwlibc) +override CLEAN_UNITS+=fpcresfix elfbfd elfres +endif +ifeq ($(FULL_TARGET),i386-wince) +override CLEAN_UNITS+=fpcresfix elfbfd elfres +endif +ifeq ($(FULL_TARGET),i386-embedded) +override CLEAN_UNITS+=fpcresfix elfbfd elfres +endif +ifeq ($(FULL_TARGET),i386-symbian) +override CLEAN_UNITS+=fpcresfix elfbfd elfres +endif +ifeq ($(FULL_TARGET),m68k-linux) +override CLEAN_UNITS+=fpcresfix elfbfd elfres +endif +ifeq ($(FULL_TARGET),m68k-freebsd) +override CLEAN_UNITS+=fpcresfix elfbfd elfres +endif +ifeq ($(FULL_TARGET),m68k-netbsd) +override CLEAN_UNITS+=fpcresfix elfbfd elfres +endif +ifeq ($(FULL_TARGET),m68k-amiga) +override CLEAN_UNITS+=fpcresfix elfbfd elfres +endif +ifeq ($(FULL_TARGET),m68k-atari) +override CLEAN_UNITS+=fpcresfix elfbfd elfres +endif +ifeq ($(FULL_TARGET),m68k-openbsd) +override CLEAN_UNITS+=fpcresfix elfbfd elfres +endif +ifeq ($(FULL_TARGET),m68k-palmos) +override CLEAN_UNITS+=fpcresfix elfbfd elfres +endif +ifeq ($(FULL_TARGET),m68k-embedded) +override CLEAN_UNITS+=fpcresfix elfbfd elfres +endif +ifeq ($(FULL_TARGET),powerpc-linux) +override CLEAN_UNITS+=fpcresfix elfbfd elfres +endif +ifeq ($(FULL_TARGET),powerpc-netbsd) +override CLEAN_UNITS+=fpcresfix elfbfd elfres +endif +ifeq ($(FULL_TARGET),powerpc-amiga) +override CLEAN_UNITS+=fpcresfix elfbfd elfres +endif +ifeq ($(FULL_TARGET),powerpc-macos) +override CLEAN_UNITS+=fpcresfix elfbfd elfres +endif +ifeq ($(FULL_TARGET),powerpc-darwin) +override CLEAN_UNITS+=fpcresfix elfbfd elfres +endif +ifeq ($(FULL_TARGET),powerpc-morphos) +override CLEAN_UNITS+=fpcresfix elfbfd elfres +endif +ifeq ($(FULL_TARGET),powerpc-embedded) +override CLEAN_UNITS+=fpcresfix elfbfd elfres +endif +ifeq ($(FULL_TARGET),sparc-linux) +override CLEAN_UNITS+=fpcresfix elfbfd elfres +endif +ifeq ($(FULL_TARGET),sparc-netbsd) +override CLEAN_UNITS+=fpcresfix elfbfd elfres +endif +ifeq ($(FULL_TARGET),sparc-solaris) +override CLEAN_UNITS+=fpcresfix elfbfd elfres +endif +ifeq ($(FULL_TARGET),sparc-embedded) +override CLEAN_UNITS+=fpcresfix elfbfd elfres +endif +ifeq ($(FULL_TARGET),x86_64-linux) +override CLEAN_UNITS+=fpcresfix elfbfd elfres +endif +ifeq ($(FULL_TARGET),x86_64-freebsd) +override CLEAN_UNITS+=fpcresfix elfbfd elfres +endif +ifeq ($(FULL_TARGET),x86_64-darwin) +override CLEAN_UNITS+=fpcresfix elfbfd elfres +endif +ifeq ($(FULL_TARGET),x86_64-win64) +override CLEAN_UNITS+=fpcresfix elfbfd elfres +endif +ifeq ($(FULL_TARGET),x86_64-embedded) +override CLEAN_UNITS+=fpcresfix elfbfd elfres +endif +ifeq ($(FULL_TARGET),arm-linux) +override CLEAN_UNITS+=fpcresfix elfbfd elfres +endif +ifeq ($(FULL_TARGET),arm-palmos) +override CLEAN_UNITS+=fpcresfix elfbfd elfres +endif +ifeq ($(FULL_TARGET),arm-wince) +override CLEAN_UNITS+=fpcresfix elfbfd elfres +endif +ifeq ($(FULL_TARGET),arm-gba) +override CLEAN_UNITS+=fpcresfix elfbfd elfres +endif +ifeq ($(FULL_TARGET),arm-nds) +override CLEAN_UNITS+=fpcresfix elfbfd elfres +endif +ifeq ($(FULL_TARGET),arm-embedded) +override CLEAN_UNITS+=fpcresfix elfbfd elfres +endif +ifeq ($(FULL_TARGET),arm-symbian) +override CLEAN_UNITS+=fpcresfix elfbfd elfres +endif +ifeq ($(FULL_TARGET),powerpc64-linux) +override CLEAN_UNITS+=fpcresfix elfbfd elfres +endif +ifeq ($(FULL_TARGET),powerpc64-darwin) +override CLEAN_UNITS+=fpcresfix elfbfd elfres +endif +ifeq ($(FULL_TARGET),powerpc64-embedded) +override CLEAN_UNITS+=fpcresfix elfbfd elfres +endif +override INSTALL_FPCPACKAGE=y +ifdef REQUIRE_UNITSDIR +override UNITSDIR+=$(REQUIRE_UNITSDIR) +endif +ifdef REQUIRE_PACKAGESDIR +override PACKAGESDIR+=$(REQUIRE_PACKAGESDIR) +endif +ifdef ZIPINSTALL +ifneq ($(findstring $(OS_TARGET),$(UNIXs)),) +UNIXHier=1 +endif +else +ifneq ($(findstring $(OS_SOURCE),$(UNIXs)),) +UNIXHier=1 +endif +endif +ifndef INSTALL_PREFIX +ifdef PREFIX +INSTALL_PREFIX=$(PREFIX) +endif +endif +ifndef INSTALL_PREFIX +ifdef UNIXHier +INSTALL_PREFIX=/usr/local +else +ifdef INSTALL_FPCPACKAGE +INSTALL_BASEDIR:=/pp +else +INSTALL_BASEDIR:=/$(PACKAGE_NAME) +endif +endif +endif +export INSTALL_PREFIX +ifdef INSTALL_FPCSUBDIR +export INSTALL_FPCSUBDIR +endif +ifndef DIST_DESTDIR +DIST_DESTDIR:=$(BASEDIR) +endif +export DIST_DESTDIR +ifndef COMPILER_UNITTARGETDIR +ifdef PACKAGEDIR_MAIN +COMPILER_UNITTARGETDIR=$(PACKAGEDIR_MAIN)/units/$(TARGETSUFFIX) +else +COMPILER_UNITTARGETDIR=units/$(TARGETSUFFIX) +endif +endif +ifndef COMPILER_TARGETDIR +COMPILER_TARGETDIR=. +endif +ifndef INSTALL_BASEDIR +ifdef UNIXHier +ifdef INSTALL_FPCPACKAGE +INSTALL_BASEDIR:=$(INSTALL_PREFIX)/lib/fpc/$(FPC_VERSION) +else +INSTALL_BASEDIR:=$(INSTALL_PREFIX)/lib/$(PACKAGE_NAME) +endif +else +INSTALL_BASEDIR:=$(INSTALL_PREFIX) +endif +endif +ifndef INSTALL_BINDIR +ifdef UNIXHier +INSTALL_BINDIR:=$(INSTALL_PREFIX)/bin +else +INSTALL_BINDIR:=$(INSTALL_BASEDIR)/bin +ifdef INSTALL_FPCPACKAGE +ifdef CROSSCOMPILE +ifdef CROSSINSTALL +INSTALL_BINDIR:=$(INSTALL_BINDIR)/$(SOURCESUFFIX) +else +INSTALL_BINDIR:=$(INSTALL_BINDIR)/$(TARGETSUFFIX) +endif +else +INSTALL_BINDIR:=$(INSTALL_BINDIR)/$(TARGETSUFFIX) +endif +endif +endif +endif +ifndef INSTALL_UNITDIR +INSTALL_UNITDIR:=$(INSTALL_BASEDIR)/units/$(TARGETSUFFIX) +ifdef INSTALL_FPCPACKAGE +ifdef PACKAGE_NAME +INSTALL_UNITDIR:=$(INSTALL_UNITDIR)/$(PACKAGE_NAME) +endif +endif +endif +ifndef INSTALL_LIBDIR +ifdef UNIXHier +INSTALL_LIBDIR:=$(INSTALL_PREFIX)/lib +else +INSTALL_LIBDIR:=$(INSTALL_UNITDIR) +endif +endif +ifndef INSTALL_SOURCEDIR +ifdef UNIXHier +ifdef BSDhier +SRCPREFIXDIR=share/src +else +ifdef linuxHier +SRCPREFIXDIR=share/src +else +SRCPREFIXDIR=src +endif +endif +ifdef INSTALL_FPCPACKAGE +ifdef INSTALL_FPCSUBDIR +INSTALL_SOURCEDIR:=$(INSTALL_PREFIX)/$(SRCPREFIXDIR)/fpc-$(FPC_VERSION)/$(INSTALL_FPCSUBDIR)/$(PACKAGE_NAME) +else +INSTALL_SOURCEDIR:=$(INSTALL_PREFIX)/$(SRCPREFIXDIR)/fpc-$(FPC_VERSION)/$(PACKAGE_NAME) +endif +else +INSTALL_SOURCEDIR:=$(INSTALL_PREFIX)/$(SRCPREFIXDIR)/$(PACKAGE_NAME)-$(PACKAGE_VERSION) +endif +else +ifdef INSTALL_FPCPACKAGE +ifdef INSTALL_FPCSUBDIR +INSTALL_SOURCEDIR:=$(INSTALL_BASEDIR)/source/$(INSTALL_FPCSUBDIR)/$(PACKAGE_NAME) +else +INSTALL_SOURCEDIR:=$(INSTALL_BASEDIR)/source/$(PACKAGE_NAME) +endif +else +INSTALL_SOURCEDIR:=$(INSTALL_BASEDIR)/source +endif +endif +endif +ifndef INSTALL_DOCDIR +ifdef UNIXHier +ifdef BSDhier +DOCPREFIXDIR=share/doc +else +ifdef linuxHier +DOCPREFIXDIR=share/doc +else +DOCPREFIXDIR=doc +endif +endif +ifdef INSTALL_FPCPACKAGE +INSTALL_DOCDIR:=$(INSTALL_PREFIX)/$(DOCPREFIXDIR)/fpc-$(FPC_VERSION)/$(PACKAGE_NAME) +else +INSTALL_DOCDIR:=$(INSTALL_PREFIX)/$(DOCPREFIXDIR)/$(PACKAGE_NAME)-$(PACKAGE_VERSION) +endif +else +ifdef INSTALL_FPCPACKAGE +INSTALL_DOCDIR:=$(INSTALL_BASEDIR)/doc/$(PACKAGE_NAME) +else +INSTALL_DOCDIR:=$(INSTALL_BASEDIR)/doc +endif +endif +endif +ifndef INSTALL_EXAMPLEDIR +ifdef UNIXHier +ifdef INSTALL_FPCPACKAGE +ifdef BSDhier +INSTALL_EXAMPLEDIR:=$(INSTALL_PREFIX)/share/examples/fpc-$(FPC_VERSION)/$(PACKAGE_NAME) +else +ifdef linuxHier +INSTALL_EXAMPLEDIR:=$(INSTALL_DOCDIR)/examples +else +INSTALL_EXAMPLEDIR:=$(INSTALL_PREFIX)/doc/fpc-$(FPC_VERSION)/examples/$(PACKAGE_NAME) +endif +endif +else +ifdef BSDhier +INSTALL_EXAMPLEDIR:=$(INSTALL_PREFIX)/share/examples/$(PACKAGE_NAME)-$(PACKAGE_VERSION) +else +ifdef linuxHier +INSTALL_EXAMPLEDIR:=$(INSTALL_DOCDIR)/examples/$(PACKAGE_NAME)-$(PACKAGE_VERSION) +else +INSTALL_EXAMPLEDIR:=$(INSTALL_PREFIX)/doc/$(PACKAGE_NAME)-$(PACKAGE_VERSION) +endif +endif +endif +else +ifdef INSTALL_FPCPACKAGE +INSTALL_EXAMPLEDIR:=$(INSTALL_BASEDIR)/examples/$(PACKAGE_NAME) +else +INSTALL_EXAMPLEDIR:=$(INSTALL_BASEDIR)/examples +endif +endif +endif +ifndef INSTALL_DATADIR +INSTALL_DATADIR=$(INSTALL_BASEDIR) +endif +ifndef INSTALL_SHAREDDIR +INSTALL_SHAREDDIR=$(INSTALL_PREFIX)/lib +endif +ifdef CROSSCOMPILE +ifndef CROSSBINDIR +CROSSBINDIR:=$(wildcard $(CROSSTARGETDIR)/bin/$(SOURCESUFFIX)) +ifeq ($(CROSSBINDIR),) +CROSSBINDIR:=$(wildcard $(INSTALL_BASEDIR)/cross/$(TARGETSUFFIX)/bin/$(FULL_SOURCE)) +endif +endif +else +CROSSBINDIR= +endif +BATCHEXT=.bat +LOADEREXT=.as +EXEEXT=.exe +PPLEXT=.ppl +PPUEXT=.ppu +OEXT=.o +ASMEXT=.s +SMARTEXT=.sl +STATICLIBEXT=.a +SHAREDLIBEXT=.so +SHAREDLIBPREFIX=libfp +STATICLIBPREFIX=libp +IMPORTLIBPREFIX=libimp +RSTEXT=.rst +ifeq ($(findstring 1.0.,$(FPC_VERSION)),) +ifeq ($(OS_TARGET),go32v1) +STATICLIBPREFIX= +SHORTSUFFIX=v1 +endif +ifeq ($(OS_TARGET),go32v2) +STATICLIBPREFIX= +SHORTSUFFIX=dos +endif +ifeq ($(OS_TARGET),watcom) +STATICLIBPREFIX= +OEXT=.obj +ASMEXT=.asm +SHAREDLIBEXT=.dll +SHORTSUFFIX=wat +endif +ifeq ($(OS_TARGET),linux) +BATCHEXT=.sh +EXEEXT= +HASSHAREDLIB=1 +SHORTSUFFIX=lnx +endif +ifeq ($(OS_TARGET),freebsd) +BATCHEXT=.sh +EXEEXT= +HASSHAREDLIB=1 +SHORTSUFFIX=fbs +endif +ifeq ($(OS_TARGET),netbsd) +BATCHEXT=.sh +EXEEXT= +HASSHAREDLIB=1 +SHORTSUFFIX=nbs +endif +ifeq ($(OS_TARGET),openbsd) +BATCHEXT=.sh +EXEEXT= +HASSHAREDLIB=1 +SHORTSUFFIX=obs +endif +ifeq ($(OS_TARGET),win32) +SHAREDLIBEXT=.dll +SHORTSUFFIX=w32 +endif +ifeq ($(OS_TARGET),os2) +BATCHEXT=.cmd +AOUTEXT=.out +STATICLIBPREFIX= +SHAREDLIBEXT=.dll +SHORTSUFFIX=os2 +ECHO=echo +endif +ifeq ($(OS_TARGET),emx) +BATCHEXT=.cmd +AOUTEXT=.out +STATICLIBPREFIX= +SHAREDLIBEXT=.dll +SHORTSUFFIX=emx +ECHO=echo +endif +ifeq ($(OS_TARGET),amiga) +EXEEXT= +SHAREDLIBEXT=.library +SHORTSUFFIX=amg +endif +ifeq ($(OS_TARGET),morphos) +EXEEXT= +SHAREDLIBEXT=.library +SHORTSUFFIX=mos +endif +ifeq ($(OS_TARGET),atari) +EXEEXT=.ttp +SHORTSUFFIX=ata +endif +ifeq ($(OS_TARGET),beos) +BATCHEXT=.sh +EXEEXT= +SHORTSUFFIX=be +endif +ifeq ($(OS_TARGET),solaris) +BATCHEXT=.sh +EXEEXT= +SHORTSUFFIX=sun +endif +ifeq ($(OS_TARGET),qnx) +BATCHEXT=.sh +EXEEXT= +SHORTSUFFIX=qnx +endif +ifeq ($(OS_TARGET),netware) +EXEEXT=.nlm +STATICLIBPREFIX= +SHORTSUFFIX=nw +endif +ifeq ($(OS_TARGET),netwlibc) +EXEEXT=.nlm +STATICLIBPREFIX= +SHORTSUFFIX=nwl +endif +ifeq ($(OS_TARGET),macos) +BATCHEXT= +EXEEXT= +DEBUGSYMEXT=.xcoff +SHORTSUFFIX=mac +endif +ifeq ($(OS_TARGET),darwin) +BATCHEXT=.sh +EXEEXT= +HASSHAREDLIB=1 +SHORTSUFFIX=dwn +endif +ifeq ($(OS_TARGET),gba) +EXEEXT=.gba +SHAREDLIBEXT=.so +SHORTSUFFIX=gba +endif +ifeq ($(OS_TARGET),symbian) +SHAREDLIBEXT=.dll +SHORTSUFFIX=symbian +endif +else +ifeq ($(OS_TARGET),go32v1) +PPUEXT=.pp1 +OEXT=.o1 +ASMEXT=.s1 +SMARTEXT=.sl1 +STATICLIBEXT=.a1 +SHAREDLIBEXT=.so1 +STATICLIBPREFIX= +SHORTSUFFIX=v1 +endif +ifeq ($(OS_TARGET),go32v2) +STATICLIBPREFIX= +SHORTSUFFIX=dos +endif +ifeq ($(OS_TARGET),watcom) +STATICLIBPREFIX= +SHORTSUFFIX=wat +endif +ifeq ($(OS_TARGET),linux) +BATCHEXT=.sh +EXEEXT= +HASSHAREDLIB=1 +SHORTSUFFIX=lnx +endif +ifeq ($(OS_TARGET),freebsd) +BATCHEXT=.sh +EXEEXT= +HASSHAREDLIB=1 +SHORTSUFFIX=fbs +endif +ifeq ($(OS_TARGET),netbsd) +BATCHEXT=.sh +EXEEXT= +HASSHAREDLIB=1 +SHORTSUFFIX=nbs +endif +ifeq ($(OS_TARGET),openbsd) +BATCHEXT=.sh +EXEEXT= +HASSHAREDLIB=1 +SHORTSUFFIX=obs +endif +ifeq ($(OS_TARGET),win32) +PPUEXT=.ppw +OEXT=.ow +ASMEXT=.sw +SMARTEXT=.slw +STATICLIBEXT=.aw +SHAREDLIBEXT=.dll +SHORTSUFFIX=w32 +endif +ifeq ($(OS_TARGET),os2) +BATCHEXT=.cmd +PPUEXT=.ppo +ASMEXT=.so2 +OEXT=.oo2 +AOUTEXT=.out +SMARTEXT=.sl2 +STATICLIBPREFIX= +STATICLIBEXT=.ao2 +SHAREDLIBEXT=.dll +SHORTSUFFIX=os2 +ECHO=echo +endif +ifeq ($(OS_TARGET),amiga) +EXEEXT= +PPUEXT=.ppu +ASMEXT=.s +OEXT=.o +SMARTEXT=.sl +STATICLIBEXT=.a +SHAREDLIBEXT=.library +SHORTSUFFIX=amg +endif +ifeq ($(OS_TARGET),atari) +PPUEXT=.ppu +ASMEXT=.s +OEXT=.o +SMARTEXT=.sl +STATICLIBEXT=.a +EXEEXT=.ttp +SHORTSUFFIX=ata +endif +ifeq ($(OS_TARGET),beos) +BATCHEXT=.sh +PPUEXT=.ppu +ASMEXT=.s +OEXT=.o +SMARTEXT=.sl +STATICLIBEXT=.a +EXEEXT= +SHORTSUFFIX=be +endif +ifeq ($(OS_TARGET),solaris) +BATCHEXT=.sh +PPUEXT=.ppu +ASMEXT=.s +OEXT=.o +SMARTEXT=.sl +STATICLIBEXT=.a +EXEEXT= +SHORTSUFFIX=sun +endif +ifeq ($(OS_TARGET),qnx) +BATCHEXT=.sh +PPUEXT=.ppu +ASMEXT=.s +OEXT=.o +SMARTEXT=.sl +STATICLIBEXT=.a +EXEEXT= +SHORTSUFFIX=qnx +endif +ifeq ($(OS_TARGET),netware) +STATICLIBPREFIX= +PPUEXT=.ppu +OEXT=.o +ASMEXT=.s +SMARTEXT=.sl +STATICLIBEXT=.a +SHAREDLIBEXT=.nlm +EXEEXT=.nlm +SHORTSUFFIX=nw +endif +ifeq ($(OS_TARGET),netwlibc) +STATICLIBPREFIX= +PPUEXT=.ppu +OEXT=.o +ASMEXT=.s +SMARTEXT=.sl +STATICLIBEXT=.a +SHAREDLIBEXT=.nlm +EXEEXT=.nlm +SHORTSUFFIX=nwl +endif +ifeq ($(OS_TARGET),macos) +BATCHEXT= +PPUEXT=.ppu +ASMEXT=.s +OEXT=.o +SMARTEXT=.sl +STATICLIBEXT=.a +EXEEXT= +DEBUGSYMEXT=.xcoff +SHORTSUFFIX=mac +endif +endif +ifneq ($(findstring $(OS_SOURCE),$(LIMIT83fs)),) +FPCMADE=fpcmade.$(SHORTSUFFIX) +ZIPSUFFIX=$(SHORTSUFFIX) +ZIPCROSSPREFIX= +ZIPSOURCESUFFIX=src +ZIPEXAMPLESUFFIX=exm +else +FPCMADE=fpcmade.$(TARGETSUFFIX) +ZIPSOURCESUFFIX=.source +ZIPEXAMPLESUFFIX=.examples +ifdef CROSSCOMPILE +ZIPSUFFIX=.$(SOURCESUFFIX) +ZIPCROSSPREFIX=$(TARGETSUFFIX)- +else +ZIPSUFFIX=.$(TARGETSUFFIX) +ZIPCROSSPREFIX= +endif +endif +ifndef ECHO +ECHO:=$(strip $(wildcard $(addsuffix /gecho$(SRCEXEEXT),$(SEARCHPATH)))) +ifeq ($(ECHO),) +ECHO:=$(strip $(wildcard $(addsuffix /echo$(SRCEXEEXT),$(SEARCHPATH)))) +ifeq ($(ECHO),) +ECHO= __missing_command_ECHO +else +ECHO:=$(firstword $(ECHO)) +endif +else +ECHO:=$(firstword $(ECHO)) +endif +endif +export ECHO +ifndef DATE +DATE:=$(strip $(wildcard $(addsuffix /gdate$(SRCEXEEXT),$(SEARCHPATH)))) +ifeq ($(DATE),) +DATE:=$(strip $(wildcard $(addsuffix /date$(SRCEXEEXT),$(SEARCHPATH)))) +ifeq ($(DATE),) +DATE= __missing_command_DATE +else +DATE:=$(firstword $(DATE)) +endif +else +DATE:=$(firstword $(DATE)) +endif +endif +export DATE +ifndef GINSTALL +GINSTALL:=$(strip $(wildcard $(addsuffix /ginstall$(SRCEXEEXT),$(SEARCHPATH)))) +ifeq ($(GINSTALL),) +GINSTALL:=$(strip $(wildcard $(addsuffix /install$(SRCEXEEXT),$(SEARCHPATH)))) +ifeq ($(GINSTALL),) +GINSTALL= __missing_command_GINSTALL +else +GINSTALL:=$(firstword $(GINSTALL)) +endif +else +GINSTALL:=$(firstword $(GINSTALL)) +endif +endif +export GINSTALL +ifndef CPPROG +CPPROG:=$(strip $(wildcard $(addsuffix /cp$(SRCEXEEXT),$(SEARCHPATH)))) +ifeq ($(CPPROG),) +CPPROG= __missing_command_CPPROG +else +CPPROG:=$(firstword $(CPPROG)) +endif +endif +export CPPROG +ifndef RMPROG +RMPROG:=$(strip $(wildcard $(addsuffix /rm$(SRCEXEEXT),$(SEARCHPATH)))) +ifeq ($(RMPROG),) +RMPROG= __missing_command_RMPROG +else +RMPROG:=$(firstword $(RMPROG)) +endif +endif +export RMPROG +ifndef MVPROG +MVPROG:=$(strip $(wildcard $(addsuffix /mv$(SRCEXEEXT),$(SEARCHPATH)))) +ifeq ($(MVPROG),) +MVPROG= __missing_command_MVPROG +else +MVPROG:=$(firstword $(MVPROG)) +endif +endif +export MVPROG +ifndef MKDIRPROG +MKDIRPROG:=$(strip $(wildcard $(addsuffix /gmkdir$(SRCEXEEXT),$(SEARCHPATH)))) +ifeq ($(MKDIRPROG),) +MKDIRPROG:=$(strip $(wildcard $(addsuffix /mkdir$(SRCEXEEXT),$(SEARCHPATH)))) +ifeq ($(MKDIRPROG),) +MKDIRPROG= __missing_command_MKDIRPROG +else +MKDIRPROG:=$(firstword $(MKDIRPROG)) +endif +else +MKDIRPROG:=$(firstword $(MKDIRPROG)) +endif +endif +export MKDIRPROG +ifndef ECHOREDIR +ifndef inUnix +ECHOREDIR=echo +else +ECHOREDIR=$(ECHO) +endif +endif +ifndef COPY +COPY:=$(CPPROG) -fp +endif +ifndef COPYTREE +COPYTREE:=$(CPPROG) -Rfp +endif +ifndef MKDIRTREE +MKDIRTREE:=$(MKDIRPROG) -p +endif +ifndef MOVE +MOVE:=$(MVPROG) -f +endif +ifndef DEL +DEL:=$(RMPROG) -f +endif +ifndef DELTREE +DELTREE:=$(RMPROG) -rf +endif +ifndef INSTALL +ifdef inUnix +INSTALL:=$(GINSTALL) -c -m 644 +else +INSTALL:=$(COPY) +endif +endif +ifndef INSTALLEXE +ifdef inUnix +INSTALLEXE:=$(GINSTALL) -c -m 755 +else +INSTALLEXE:=$(COPY) +endif +endif +ifndef MKDIR +MKDIR:=$(GINSTALL) -m 755 -d +endif +export ECHOREDIR COPY COPYTREE MOVE DEL DELTREE INSTALL INSTALLEXE MKDIR +ifndef PPUMOVE +PPUMOVE:=$(strip $(wildcard $(addsuffix /ppumove$(SRCEXEEXT),$(SEARCHPATH)))) +ifeq ($(PPUMOVE),) +PPUMOVE= __missing_command_PPUMOVE +else +PPUMOVE:=$(firstword $(PPUMOVE)) +endif +endif +export PPUMOVE +ifndef FPCMAKE +FPCMAKE:=$(strip $(wildcard $(addsuffix /fpcmake$(SRCEXEEXT),$(SEARCHPATH)))) +ifeq ($(FPCMAKE),) +FPCMAKE= __missing_command_FPCMAKE +else +FPCMAKE:=$(firstword $(FPCMAKE)) +endif +endif +export FPCMAKE +ifndef ZIPPROG +ZIPPROG:=$(strip $(wildcard $(addsuffix /zip$(SRCEXEEXT),$(SEARCHPATH)))) +ifeq ($(ZIPPROG),) +ZIPPROG= __missing_command_ZIPPROG +else +ZIPPROG:=$(firstword $(ZIPPROG)) +endif +endif +export ZIPPROG +ifndef TARPROG +TARPROG:=$(strip $(wildcard $(addsuffix /gtar$(SRCEXEEXT),$(SEARCHPATH)))) +ifeq ($(TARPROG),) +TARPROG:=$(strip $(wildcard $(addsuffix /tar$(SRCEXEEXT),$(SEARCHPATH)))) +ifeq ($(TARPROG),) +TARPROG= __missing_command_TARPROG +else +TARPROG:=$(firstword $(TARPROG)) +endif +else +TARPROG:=$(firstword $(TARPROG)) +endif +endif +export TARPROG +ASNAME=$(BINUTILSPREFIX)as +LDNAME=$(BINUTILSPREFIX)ld +ARNAME=$(BINUTILSPREFIX)ar +RCNAME=$(BINUTILSPREFIX)rc +ifneq ($(findstring 1.0.,$(FPC_VERSION)),) +ifeq ($(OS_TARGET),win32) +ifeq ($(CROSSBINDIR),) +ASNAME=asw +LDNAME=ldw +ARNAME=arw +endif +endif +endif +ifndef ASPROG +ifdef CROSSBINDIR +ASPROG=$(CROSSBINDIR)/$(ASNAME)$(SRCEXEEXT) +else +ASPROG=$(ASNAME) +endif +endif +ifndef LDPROG +ifdef CROSSBINDIR +LDPROG=$(CROSSBINDIR)/$(LDNAME)$(SRCEXEEXT) +else +LDPROG=$(LDNAME) +endif +endif +ifndef RCPROG +ifdef CROSSBINDIR +RCPROG=$(CROSSBINDIR)/$(RCNAME)$(SRCEXEEXT) +else +RCPROG=$(RCNAME) +endif +endif +ifndef ARPROG +ifdef CROSSBINDIR +ARPROG=$(CROSSBINDIR)/$(ARNAME)$(SRCEXEEXT) +else +ARPROG=$(ARNAME) +endif +endif +AS=$(ASPROG) +LD=$(LDPROG) +RC=$(RCPROG) +AR=$(ARPROG) +PPAS=ppas$(SRCBATCHEXT) +ifdef inUnix +LDCONFIG=ldconfig +else +LDCONFIG= +endif +ifdef DATE +DATESTR:=$(shell $(DATE) +%Y%m%d) +else +DATESTR= +endif +ifndef UPXPROG +ifeq ($(OS_TARGET),go32v2) +UPXPROG:=1 +endif +ifeq ($(OS_TARGET),win32) +UPXPROG:=1 +endif +ifdef UPXPROG +UPXPROG:=$(strip $(wildcard $(addsuffix /upx$(SRCEXEEXT),$(SEARCHPATH)))) +ifeq ($(UPXPROG),) +UPXPROG= +else +UPXPROG:=$(firstword $(UPXPROG)) +endif +else +UPXPROG= +endif +endif +export UPXPROG +ZIPOPT=-9 +ZIPEXT=.zip +ifeq ($(USETAR),bz2) +TAROPT=vj +TAREXT=.tar.bz2 +else +TAROPT=vz +TAREXT=.tar.gz +endif +override REQUIRE_PACKAGES=rtl rtl fcl-res +ifeq ($(FULL_TARGET),i386-linux) +REQUIRE_PACKAGES_RTL=1 +REQUIRE_PACKAGES_FCL-RES=1 +endif +ifeq ($(FULL_TARGET),i386-go32v2) +REQUIRE_PACKAGES_RTL=1 +REQUIRE_PACKAGES_FCL-RES=1 +endif +ifeq ($(FULL_TARGET),i386-win32) +REQUIRE_PACKAGES_RTL=1 +REQUIRE_PACKAGES_FCL-RES=1 +endif +ifeq ($(FULL_TARGET),i386-os2) +REQUIRE_PACKAGES_RTL=1 +REQUIRE_PACKAGES_FCL-RES=1 +endif +ifeq ($(FULL_TARGET),i386-freebsd) +REQUIRE_PACKAGES_RTL=1 +REQUIRE_PACKAGES_FCL-RES=1 +endif +ifeq ($(FULL_TARGET),i386-beos) +REQUIRE_PACKAGES_RTL=1 +REQUIRE_PACKAGES_FCL-RES=1 +endif +ifeq ($(FULL_TARGET),i386-netbsd) +REQUIRE_PACKAGES_RTL=1 +REQUIRE_PACKAGES_FCL-RES=1 +endif +ifeq ($(FULL_TARGET),i386-solaris) +REQUIRE_PACKAGES_RTL=1 +REQUIRE_PACKAGES_FCL-RES=1 +endif +ifeq ($(FULL_TARGET),i386-qnx) +REQUIRE_PACKAGES_RTL=1 +REQUIRE_PACKAGES_FCL-RES=1 +endif +ifeq ($(FULL_TARGET),i386-netware) +REQUIRE_PACKAGES_RTL=1 +REQUIRE_PACKAGES_FCL-RES=1 +endif +ifeq ($(FULL_TARGET),i386-openbsd) +REQUIRE_PACKAGES_RTL=1 +REQUIRE_PACKAGES_FCL-RES=1 +endif +ifeq ($(FULL_TARGET),i386-wdosx) +REQUIRE_PACKAGES_RTL=1 +REQUIRE_PACKAGES_FCL-RES=1 +endif +ifeq ($(FULL_TARGET),i386-darwin) +REQUIRE_PACKAGES_RTL=1 +REQUIRE_PACKAGES_FCL-RES=1 +endif +ifeq ($(FULL_TARGET),i386-emx) +REQUIRE_PACKAGES_RTL=1 +REQUIRE_PACKAGES_FCL-RES=1 +endif +ifeq ($(FULL_TARGET),i386-watcom) +REQUIRE_PACKAGES_RTL=1 +REQUIRE_PACKAGES_FCL-RES=1 +endif +ifeq ($(FULL_TARGET),i386-netwlibc) +REQUIRE_PACKAGES_RTL=1 +REQUIRE_PACKAGES_FCL-RES=1 +endif +ifeq ($(FULL_TARGET),i386-wince) +REQUIRE_PACKAGES_RTL=1 +REQUIRE_PACKAGES_FCL-RES=1 +endif +ifeq ($(FULL_TARGET),i386-embedded) +REQUIRE_PACKAGES_RTL=1 +REQUIRE_PACKAGES_FCL-RES=1 +endif +ifeq ($(FULL_TARGET),i386-symbian) +REQUIRE_PACKAGES_RTL=1 +REQUIRE_PACKAGES_FCL-RES=1 +endif +ifeq ($(FULL_TARGET),m68k-linux) +REQUIRE_PACKAGES_RTL=1 +REQUIRE_PACKAGES_FCL-RES=1 +endif +ifeq ($(FULL_TARGET),m68k-freebsd) +REQUIRE_PACKAGES_RTL=1 +REQUIRE_PACKAGES_FCL-RES=1 +endif +ifeq ($(FULL_TARGET),m68k-netbsd) +REQUIRE_PACKAGES_RTL=1 +REQUIRE_PACKAGES_FCL-RES=1 +endif +ifeq ($(FULL_TARGET),m68k-amiga) +REQUIRE_PACKAGES_RTL=1 +REQUIRE_PACKAGES_FCL-RES=1 +endif +ifeq ($(FULL_TARGET),m68k-atari) +REQUIRE_PACKAGES_RTL=1 +REQUIRE_PACKAGES_FCL-RES=1 +endif +ifeq ($(FULL_TARGET),m68k-openbsd) +REQUIRE_PACKAGES_RTL=1 +REQUIRE_PACKAGES_FCL-RES=1 +endif +ifeq ($(FULL_TARGET),m68k-palmos) +REQUIRE_PACKAGES_RTL=1 +REQUIRE_PACKAGES_FCL-RES=1 +endif +ifeq ($(FULL_TARGET),m68k-embedded) +REQUIRE_PACKAGES_RTL=1 +REQUIRE_PACKAGES_FCL-RES=1 +endif +ifeq ($(FULL_TARGET),powerpc-linux) +REQUIRE_PACKAGES_RTL=1 +REQUIRE_PACKAGES_FCL-RES=1 +endif +ifeq ($(FULL_TARGET),powerpc-netbsd) +REQUIRE_PACKAGES_RTL=1 +REQUIRE_PACKAGES_FCL-RES=1 +endif +ifeq ($(FULL_TARGET),powerpc-amiga) +REQUIRE_PACKAGES_RTL=1 +REQUIRE_PACKAGES_FCL-RES=1 +endif +ifeq ($(FULL_TARGET),powerpc-macos) +REQUIRE_PACKAGES_RTL=1 +REQUIRE_PACKAGES_FCL-RES=1 +endif +ifeq ($(FULL_TARGET),powerpc-darwin) +REQUIRE_PACKAGES_RTL=1 +REQUIRE_PACKAGES_FCL-RES=1 +endif +ifeq ($(FULL_TARGET),powerpc-morphos) +REQUIRE_PACKAGES_RTL=1 +REQUIRE_PACKAGES_FCL-RES=1 +endif +ifeq ($(FULL_TARGET),powerpc-embedded) +REQUIRE_PACKAGES_RTL=1 +REQUIRE_PACKAGES_FCL-RES=1 +endif +ifeq ($(FULL_TARGET),sparc-linux) +REQUIRE_PACKAGES_RTL=1 +REQUIRE_PACKAGES_FCL-RES=1 +endif +ifeq ($(FULL_TARGET),sparc-netbsd) +REQUIRE_PACKAGES_RTL=1 +REQUIRE_PACKAGES_FCL-RES=1 +endif +ifeq ($(FULL_TARGET),sparc-solaris) +REQUIRE_PACKAGES_RTL=1 +REQUIRE_PACKAGES_FCL-RES=1 +endif +ifeq ($(FULL_TARGET),sparc-embedded) +REQUIRE_PACKAGES_RTL=1 +REQUIRE_PACKAGES_FCL-RES=1 +endif +ifeq ($(FULL_TARGET),x86_64-linux) +REQUIRE_PACKAGES_RTL=1 +REQUIRE_PACKAGES_FCL-RES=1 +endif +ifeq ($(FULL_TARGET),x86_64-freebsd) +REQUIRE_PACKAGES_RTL=1 +REQUIRE_PACKAGES_FCL-RES=1 +endif +ifeq ($(FULL_TARGET),x86_64-darwin) +REQUIRE_PACKAGES_RTL=1 +REQUIRE_PACKAGES_FCL-RES=1 +endif +ifeq ($(FULL_TARGET),x86_64-win64) +REQUIRE_PACKAGES_RTL=1 +REQUIRE_PACKAGES_FCL-RES=1 +endif +ifeq ($(FULL_TARGET),x86_64-embedded) +REQUIRE_PACKAGES_RTL=1 +REQUIRE_PACKAGES_FCL-RES=1 +endif +ifeq ($(FULL_TARGET),arm-linux) +REQUIRE_PACKAGES_RTL=1 +REQUIRE_PACKAGES_FCL-RES=1 +endif +ifeq ($(FULL_TARGET),arm-palmos) +REQUIRE_PACKAGES_RTL=1 +REQUIRE_PACKAGES_FCL-RES=1 +endif +ifeq ($(FULL_TARGET),arm-wince) +REQUIRE_PACKAGES_RTL=1 +REQUIRE_PACKAGES_FCL-RES=1 +endif +ifeq ($(FULL_TARGET),arm-gba) +REQUIRE_PACKAGES_RTL=1 +REQUIRE_PACKAGES_FCL-RES=1 +endif +ifeq ($(FULL_TARGET),arm-nds) +REQUIRE_PACKAGES_RTL=1 +REQUIRE_PACKAGES_FCL-RES=1 +endif +ifeq ($(FULL_TARGET),arm-embedded) +REQUIRE_PACKAGES_RTL=1 +REQUIRE_PACKAGES_FCL-RES=1 +endif +ifeq ($(FULL_TARGET),arm-symbian) +REQUIRE_PACKAGES_RTL=1 +REQUIRE_PACKAGES_FCL-RES=1 +endif +ifeq ($(FULL_TARGET),powerpc64-linux) +REQUIRE_PACKAGES_RTL=1 +REQUIRE_PACKAGES_FCL-RES=1 +endif +ifeq ($(FULL_TARGET),powerpc64-darwin) +REQUIRE_PACKAGES_RTL=1 +REQUIRE_PACKAGES_FCL-RES=1 +endif +ifeq ($(FULL_TARGET),powerpc64-embedded) +REQUIRE_PACKAGES_RTL=1 +REQUIRE_PACKAGES_FCL-RES=1 +endif +ifdef REQUIRE_PACKAGES_RTL +PACKAGEDIR_RTL:=$(firstword $(subst /Makefile.fpc,,$(strip $(wildcard $(addsuffix /rtl/Makefile.fpc,$(PACKAGESDIR)))))) +ifneq ($(PACKAGEDIR_RTL),) +ifneq ($(wildcard $(PACKAGEDIR_RTL)/units/$(TARGETSUFFIX)),) +UNITDIR_RTL=$(PACKAGEDIR_RTL)/units/$(TARGETSUFFIX) +else +UNITDIR_RTL=$(PACKAGEDIR_RTL) +endif +ifdef CHECKDEPEND +$(PACKAGEDIR_RTL)/$(FPCMADE): + $(MAKE) -C $(PACKAGEDIR_RTL) $(FPCMADE) +override ALLDEPENDENCIES+=$(PACKAGEDIR_RTL)/$(FPCMADE) +endif +else +PACKAGEDIR_RTL= +UNITDIR_RTL:=$(subst /Package.fpc,,$(strip $(wildcard $(addsuffix /rtl/Package.fpc,$(UNITSDIR))))) +ifneq ($(UNITDIR_RTL),) +UNITDIR_RTL:=$(firstword $(UNITDIR_RTL)) +else +UNITDIR_RTL= +endif +endif +ifdef UNITDIR_RTL +override COMPILER_UNITDIR+=$(UNITDIR_RTL) +endif +endif +ifdef REQUIRE_PACKAGES_FCL-RES +PACKAGEDIR_FCL-RES:=$(firstword $(subst /Makefile.fpc,,$(strip $(wildcard $(addsuffix /fcl-res/Makefile.fpc,$(PACKAGESDIR)))))) +ifneq ($(PACKAGEDIR_FCL-RES),) +ifneq ($(wildcard $(PACKAGEDIR_FCL-RES)/units/$(TARGETSUFFIX)),) +UNITDIR_FCL-RES=$(PACKAGEDIR_FCL-RES)/units/$(TARGETSUFFIX) +else +UNITDIR_FCL-RES=$(PACKAGEDIR_FCL-RES) +endif +ifdef CHECKDEPEND +$(PACKAGEDIR_FCL-RES)/$(FPCMADE): + $(MAKE) -C $(PACKAGEDIR_FCL-RES) $(FPCMADE) +override ALLDEPENDENCIES+=$(PACKAGEDIR_FCL-RES)/$(FPCMADE) +endif +else +PACKAGEDIR_FCL-RES= +UNITDIR_FCL-RES:=$(subst /Package.fpc,,$(strip $(wildcard $(addsuffix /fcl-res/Package.fpc,$(UNITSDIR))))) +ifneq ($(UNITDIR_FCL-RES),) +UNITDIR_FCL-RES:=$(firstword $(UNITDIR_FCL-RES)) +else +UNITDIR_FCL-RES= +endif +endif +ifdef UNITDIR_FCL-RES +override COMPILER_UNITDIR+=$(UNITDIR_FCL-RES) +endif +endif +ifndef NOCPUDEF +override FPCOPTDEF=$(CPU_TARGET) +endif +ifneq ($(OS_TARGET),$(OS_SOURCE)) +override FPCOPT+=-T$(OS_TARGET) +endif +ifneq ($(CPU_TARGET),$(CPU_SOURCE)) +override FPCOPT+=-P$(CPU_TARGET) +endif +ifeq ($(OS_SOURCE),openbsd) +override FPCOPT+=-FD$(NEW_BINUTILS_PATH) +endif +ifndef CROSSBOOTSTRAP +ifneq ($(BINUTILSPREFIX),) +override FPCOPT+=-XP$(BINUTILSPREFIX) +endif +ifneq ($(BINUTILSPREFIX),) +override FPCOPT+=-Xr$(RLINKPATH) +endif +endif +ifdef UNITDIR +override FPCOPT+=$(addprefix -Fu,$(UNITDIR)) +endif +ifdef LIBDIR +override FPCOPT+=$(addprefix -Fl,$(LIBDIR)) +endif +ifdef OBJDIR +override FPCOPT+=$(addprefix -Fo,$(OBJDIR)) +endif +ifdef INCDIR +override FPCOPT+=$(addprefix -Fi,$(INCDIR)) +endif +ifdef LINKSMART +override FPCOPT+=-XX +endif +ifdef CREATESMART +override FPCOPT+=-CX +endif +ifdef DEBUG +override FPCOPT+=-gl +override FPCOPTDEF+=DEBUG +endif +ifdef RELEASE +ifneq ($(findstring 2.0.,$(FPC_VERSION)),) +ifeq ($(CPU_TARGET),i386) +FPCCPUOPT:=-OG2p3 +endif +ifeq ($(CPU_TARGET),powerpc) +FPCCPUOPT:=-O1r +endif +else +FPCCPUOPT:=-O2 +endif +override FPCOPT+=-Ur -Xs $(FPCCPUOPT) -n +override FPCOPTDEF+=RELEASE +endif +ifdef STRIP +override FPCOPT+=-Xs +endif +ifdef OPTIMIZE +override FPCOPT+=-O2 +endif +ifdef VERBOSE +override FPCOPT+=-vwni +endif +ifdef COMPILER_OPTIONS +override FPCOPT+=$(COMPILER_OPTIONS) +endif +ifdef COMPILER_UNITDIR +override FPCOPT+=$(addprefix -Fu,$(COMPILER_UNITDIR)) +endif +ifdef COMPILER_LIBRARYDIR +override FPCOPT+=$(addprefix -Fl,$(COMPILER_LIBRARYDIR)) +endif +ifdef COMPILER_OBJECTDIR +override FPCOPT+=$(addprefix -Fo,$(COMPILER_OBJECTDIR)) +endif +ifdef COMPILER_INCLUDEDIR +override FPCOPT+=$(addprefix -Fi,$(COMPILER_INCLUDEDIR)) +endif +ifdef CROSSBINDIR +override FPCOPT+=-FD$(CROSSBINDIR) +endif +ifdef COMPILER_TARGETDIR +override FPCOPT+=-FE$(COMPILER_TARGETDIR) +ifeq ($(COMPILER_TARGETDIR),.) +override TARGETDIRPREFIX= +else +override TARGETDIRPREFIX=$(COMPILER_TARGETDIR)/ +endif +endif +ifdef COMPILER_UNITTARGETDIR +override FPCOPT+=-FU$(COMPILER_UNITTARGETDIR) +ifeq ($(COMPILER_UNITTARGETDIR),.) +override UNITTARGETDIRPREFIX= +else +override UNITTARGETDIRPREFIX=$(COMPILER_UNITTARGETDIR)/ +endif +else +ifdef COMPILER_TARGETDIR +override COMPILER_UNITTARGETDIR=$(COMPILER_TARGETDIR) +override UNITTARGETDIRPREFIX=$(TARGETDIRPREFIX) +endif +endif +ifdef CREATESHARED +override FPCOPT+=-Cg +ifeq ($(CPU_TARGET),i386) +override FPCOPT+=-Aas +endif +endif +ifeq ($(findstring 2.0.,$(FPC_VERSION)),) +ifeq ($(OS_TARGET),linux) +ifeq ($(CPU_TARGET),x86_64) +override FPCOPT+=-Cg +endif +endif +endif +ifdef LINKSHARED +endif +ifdef OPT +override FPCOPT+=$(OPT) +endif +ifdef FPCOPTDEF +override FPCOPT+=$(addprefix -d,$(FPCOPTDEF)) +endif +ifdef CFGFILE +override FPCOPT+=@$(CFGFILE) +endif +ifdef USEENV +override FPCEXTCMD:=$(FPCOPT) +override FPCOPT:=!FPCEXTCMD +export FPCEXTCMD +endif +override AFULL_TARGET=$(CPU_TARGET)-$(OS_TARGET) +override AFULL_SOURCE=$(CPU_SOURCE)-$(OS_SOURCE) +ifneq ($(AFULL_TARGET),$(AFULL_SOURCE)) +override ACROSSCOMPILE=1 +endif +ifdef ACROSSCOMPILE +override FPCOPT+=$(CROSSOPT) +endif +override COMPILER:=$(FPC) $(FPCOPT) +ifeq (,$(findstring -s ,$(COMPILER))) +EXECPPAS= +else +ifeq ($(FULL_SOURCE),$(FULL_TARGET)) +ifdef RUNBATCH +EXECPPAS:=@$(RUNBATCH) $(PPAS) +else +EXECPPAS:=@$(PPAS) +endif +endif +endif +.PHONY: fpc_units +ifneq ($(TARGET_UNITS),) +override ALLTARGET+=fpc_units +override UNITPPUFILES=$(addsuffix $(PPUEXT),$(TARGET_UNITS)) +override IMPLICITUNITPPUFILES=$(addsuffix $(PPUEXT),$(TARGET_IMPLICITUNITS)) +override INSTALLPPUFILES+=$(UNITPPUFILES) $(IMPLICITUNITPPUFILES) +override CLEANPPUFILES+=$(UNITPPUFILES) $(IMPLICITUNITPPUFILES) +endif +fpc_units: $(COMPILER_UNITTARGETDIR) $(UNITPPUFILES) +.PHONY: fpc_exes +ifndef CROSSINSTALL +ifneq ($(TARGET_PROGRAMS),) +override EXEFILES=$(addsuffix $(EXEEXT),$(TARGET_PROGRAMS)) +override EXEOFILES:=$(addsuffix $(OEXT),$(TARGET_PROGRAMS)) $(addprefix $(STATICLIBPREFIX),$(addsuffix $(STATICLIBEXT),$(TARGET_PROGRAMS))) $(addprefix $(IMPORTLIBPREFIX),$(addsuffix $(STATICLIBEXT),$(TARGET_PROGRAMS))) +override ALLTARGET+=fpc_exes +override INSTALLEXEFILES+=$(EXEFILES) +override CLEANEXEFILES+=$(EXEFILES) $(EXEOFILES) +ifeq ($(OS_TARGET),os2) +override CLEANEXEFILES+=$(addsuffix $(AOUTEXT),$(TARGET_PROGRAMS)) +endif +ifeq ($(OS_TARGET),emx) +override CLEANEXEFILES+=$(addsuffix $(AOUTEXT),$(TARGET_PROGRAMS)) +endif +endif +endif +fpc_exes: $(COMPILER_TARGETDIR) $(COMPILER_UNITTARGETDIR) $(EXEFILES) +ifdef TARGET_RSTS +override RSTFILES=$(addsuffix $(RSTEXT),$(TARGET_RSTS)) +override CLEANRSTFILES+=$(RSTFILES) +endif +.PHONY: fpc_all fpc_smart fpc_debug fpc_release fpc_shared +$(FPCMADE): $(ALLDEPENDENCIES) $(ALLTARGET) + @$(ECHOREDIR) Compiled > $(FPCMADE) +fpc_all: $(FPCMADE) +fpc_smart: + $(MAKE) all LINKSMART=1 CREATESMART=1 +fpc_debug: + $(MAKE) all DEBUG=1 +fpc_release: + $(MAKE) all RELEASE=1 +.SUFFIXES: $(EXEEXT) $(PPUEXT) $(OEXT) .pas .lpr .dpr .pp .rc .res +$(COMPILER_UNITTARGETDIR): + $(MKDIRTREE) $(COMPILER_UNITTARGETDIR) +$(COMPILER_TARGETDIR): + $(MKDIRTREE) $(COMPILER_TARGETDIR) +%$(PPUEXT): %.pp + $(COMPILER) $< + $(EXECPPAS) +%$(PPUEXT): %.pas + $(COMPILER) $< + $(EXECPPAS) +%$(EXEEXT): %.pp + $(COMPILER) $< + $(EXECPPAS) +%$(EXEEXT): %.pas + $(COMPILER) $< + $(EXECPPAS) +%$(EXEEXT): %.lpr + $(COMPILER) $< + $(EXECPPAS) +%$(EXEEXT): %.dpr + $(COMPILER) $< + $(EXECPPAS) +%.res: %.rc + windres -i $< -o $@ +vpath %.pp $(COMPILER_SOURCEDIR) $(COMPILER_INCLUDEDIR) +vpath %.pas $(COMPILER_SOURCEDIR) $(COMPILER_INCLUDEDIR) +vpath %.lpr $(COMPILER_SOURCEDIR) $(COMPILER_INCLUDEDIR) +vpath %.dpr $(COMPILER_SOURCEDIR) $(COMPILER_INCLUDEDIR) +vpath %.inc $(COMPILER_INCLUDEDIR) +vpath %$(OEXT) $(COMPILER_UNITTARGETDIR) +vpath %$(PPUEXT) $(COMPILER_UNITTARGETDIR) +.PHONY: fpc_shared +override INSTALLTARGET+=fpc_shared_install +ifndef SHARED_LIBVERSION +SHARED_LIBVERSION=$(FPC_VERSION) +endif +ifndef SHARED_LIBNAME +SHARED_LIBNAME=$(PACKAGE_NAME) +endif +ifndef SHARED_FULLNAME +SHARED_FULLNAME=$(SHAREDLIBPREFIX)$(SHARED_LIBNAME)-$(SHARED_LIBVERSION)$(SHAREDLIBEXT) +endif +ifndef SHARED_LIBUNITS +SHARED_LIBUNITS:=$(TARGET_UNITS) $(TARGET_IMPLICITUNITS) +override SHARED_LIBUNITS:=$(filter-out $(INSTALL_BUILDUNIT),$(SHARED_LIBUNITS)) +endif +fpc_shared: +ifdef HASSHAREDLIB + $(MAKE) all CREATESHARED=1 LINKSHARED=1 CREATESMART=1 +ifneq ($(SHARED_BUILD),n) + $(PPUMOVE) -q $(SHARED_LIBUNITS) -i$(COMPILER_UNITTARGETDIR) -o$(SHARED_FULLNAME) -d$(COMPILER_UNITTARGETDIR) +endif +else + @$(ECHO) Shared Libraries not supported +endif +fpc_shared_install: +ifneq ($(SHARED_BUILD),n) +ifneq ($(SHARED_LIBUNITS),) +ifneq ($(wildcard $(COMPILER_UNITTARGETDIR)/$(SHARED_FULLNAME)),) + $(INSTALL) $(COMPILER_UNITTARGETDIR)/$(SHARED_FULLNAME) $(INSTALL_SHAREDDIR) +endif +endif +endif +.PHONY: fpc_install fpc_sourceinstall fpc_exampleinstall +ifdef INSTALL_UNITS +override INSTALLPPUFILES+=$(addsuffix $(PPUEXT),$(INSTALL_UNITS)) +endif +ifdef INSTALL_BUILDUNIT +override INSTALLPPUFILES:=$(filter-out $(INSTALL_BUILDUNIT)$(PPUEXT),$(INSTALLPPUFILES)) +endif +ifdef INSTALLPPUFILES +override INSTALLPPULINKFILES:=$(subst $(PPUEXT),$(OEXT),$(INSTALLPPUFILES)) $(addprefix $(STATICLIBPREFIX),$(subst $(PPUEXT),$(STATICLIBEXT),$(INSTALLPPUFILES))) $(addprefix $(IMPORTLIBPREFIX),$(subst $(PPUEXT),$(STATICLIBEXT),$(INSTALLPPUFILES))) +ifneq ($(UNITTARGETDIRPREFIX),) +override INSTALLPPUFILES:=$(addprefix $(UNITTARGETDIRPREFIX),$(notdir $(INSTALLPPUFILES))) +override INSTALLPPULINKFILES:=$(wildcard $(addprefix $(UNITTARGETDIRPREFIX),$(notdir $(INSTALLPPULINKFILES)))) +endif +override INSTALL_CREATEPACKAGEFPC=1 +endif +ifdef INSTALLEXEFILES +ifneq ($(TARGETDIRPREFIX),) +override INSTALLEXEFILES:=$(addprefix $(TARGETDIRPREFIX),$(notdir $(INSTALLEXEFILES))) +endif +endif +fpc_install: all $(INSTALLTARGET) +ifdef INSTALLEXEFILES + $(MKDIR) $(INSTALL_BINDIR) +ifdef UPXPROG + -$(UPXPROG) $(INSTALLEXEFILES) +endif + $(INSTALLEXE) $(INSTALLEXEFILES) $(INSTALL_BINDIR) +endif +ifdef INSTALL_CREATEPACKAGEFPC +ifdef FPCMAKE +ifdef PACKAGE_VERSION +ifneq ($(wildcard Makefile.fpc),) + $(FPCMAKE) -p -T$(CPU_TARGET)-$(OS_TARGET) Makefile.fpc + $(MKDIR) $(INSTALL_UNITDIR) + $(INSTALL) Package.fpc $(INSTALL_UNITDIR) +endif +endif +endif +endif +ifdef INSTALLPPUFILES + $(MKDIR) $(INSTALL_UNITDIR) + $(INSTALL) $(INSTALLPPUFILES) $(INSTALL_UNITDIR) +ifneq ($(INSTALLPPULINKFILES),) + $(INSTALL) $(INSTALLPPULINKFILES) $(INSTALL_UNITDIR) +endif +ifneq ($(wildcard $(LIB_FULLNAME)),) + $(MKDIR) $(INSTALL_LIBDIR) + $(INSTALL) $(LIB_FULLNAME) $(INSTALL_LIBDIR) +ifdef inUnix + ln -sf $(LIB_FULLNAME) $(INSTALL_LIBDIR)/$(LIB_NAME) +endif +endif +endif +ifdef INSTALL_FILES + $(MKDIR) $(INSTALL_DATADIR) + $(INSTALL) $(INSTALL_FILES) $(INSTALL_DATADIR) +endif +fpc_sourceinstall: distclean + $(MKDIR) $(INSTALL_SOURCEDIR) + $(COPYTREE) $(BASEDIR)/* $(INSTALL_SOURCEDIR) +fpc_exampleinstall: $(addsuffix _distclean,$(TARGET_EXAMPLEDIRS)) +ifdef HASEXAMPLES + $(MKDIR) $(INSTALL_EXAMPLEDIR) +endif +ifdef EXAMPLESOURCEFILES + $(COPY) $(EXAMPLESOURCEFILES) $(INSTALL_EXAMPLEDIR) +endif +ifdef TARGET_EXAMPLEDIRS + $(COPYTREE) $(addsuffix /*,$(TARGET_EXAMPLEDIRS)) $(INSTALL_EXAMPLEDIR) +endif +.PHONY: fpc_clean fpc_cleanall fpc_distclean +ifdef EXEFILES +override CLEANEXEFILES:=$(addprefix $(TARGETDIRPREFIX),$(CLEANEXEFILES)) +endif +ifdef CLEAN_UNITS +override CLEANPPUFILES+=$(addsuffix $(PPUEXT),$(CLEAN_UNITS)) +endif +ifdef CLEANPPUFILES +override CLEANPPULINKFILES:=$(subst $(PPUEXT),$(OEXT),$(CLEANPPUFILES)) $(addprefix $(STATICLIBPREFIX),$(subst $(PPUEXT),$(STATICLIBEXT),$(CLEANPPUFILES))) $(addprefix $(IMPORTLIBPREFIX),$(subst $(PPUEXT),$(STATICLIBEXT),$(CLEANPPUFILES))) +ifdef DEBUGSYMEXT +override CLEANPPULINKFILES+=$(subst $(PPUEXT),$(DEBUGSYMEXT),$(CLEANPPUFILES)) +endif +override CLEANPPUFILES:=$(addprefix $(UNITTARGETDIRPREFIX),$(CLEANPPUFILES)) +override CLEANPPULINKFILES:=$(wildcard $(addprefix $(UNITTARGETDIRPREFIX),$(CLEANPPULINKFILES))) +endif +fpc_clean: $(CLEANTARGET) +ifdef CLEANEXEFILES + -$(DEL) $(CLEANEXEFILES) +endif +ifdef CLEANPPUFILES + -$(DEL) $(CLEANPPUFILES) +endif +ifneq ($(CLEANPPULINKFILES),) + -$(DEL) $(CLEANPPULINKFILES) +endif +ifdef CLEANRSTFILES + -$(DEL) $(addprefix $(UNITTARGETDIRPREFIX),$(CLEANRSTFILES)) +endif +ifdef CLEAN_FILES + -$(DEL) $(CLEAN_FILES) +endif +ifdef LIB_NAME + -$(DEL) $(LIB_NAME) $(LIB_FULLNAME) +endif + -$(DEL) $(FPCMADE) Package.fpc $(PPAS) script.res link.res $(FPCEXTFILE) $(REDIRFILE) + -$(DEL) *$(ASMEXT) *_ppas$(BATCHEXT) +fpc_cleanall: $(CLEANTARGET) +ifdef CLEANEXEFILES + -$(DEL) $(CLEANEXEFILES) +endif +ifdef COMPILER_UNITTARGETDIR +ifdef CLEANPPUFILES + -$(DEL) $(CLEANPPUFILES) +endif +ifneq ($(CLEANPPULINKFILES),) + -$(DEL) $(CLEANPPULINKFILES) +endif +ifdef CLEANRSTFILES + -$(DEL) $(addprefix $(UNITTARGETDIRPREFIX),$(CLEANRSTFILES)) +endif +endif + -$(DELTREE) units + -$(DEL) *$(OEXT) *$(PPUEXT) *$(RSTEXT) *$(ASMEXT) *$(STATICLIBEXT) *$(SHAREDLIBEXT) *$(PPLEXT) +ifneq ($(PPUEXT),.ppu) + -$(DEL) *.o *.ppu *.a +endif + -$(DELTREE) *$(SMARTEXT) + -$(DEL) fpcmade.* Package.fpc $(PPAS) script.res link.res $(FPCEXTFILE) $(REDIRFILE) + -$(DEL) *_ppas$(BATCHEXT) +ifdef AOUTEXT + -$(DEL) *$(AOUTEXT) +endif +ifdef DEBUGSYMEXT + -$(DEL) *$(DEBUGSYMEXT) +endif +fpc_distclean: cleanall +.PHONY: fpc_baseinfo +override INFORULES+=fpc_baseinfo +fpc_baseinfo: + @$(ECHO) + @$(ECHO) == Package info == + @$(ECHO) Package Name..... $(PACKAGE_NAME) + @$(ECHO) Package Version.. $(PACKAGE_VERSION) + @$(ECHO) + @$(ECHO) == Configuration info == + @$(ECHO) + @$(ECHO) FPC.......... $(FPC) + @$(ECHO) FPC Version.. $(FPC_VERSION) + @$(ECHO) Source CPU... $(CPU_SOURCE) + @$(ECHO) Target CPU... $(CPU_TARGET) + @$(ECHO) Source OS.... $(OS_SOURCE) + @$(ECHO) Target OS.... $(OS_TARGET) + @$(ECHO) Full Source.. $(FULL_SOURCE) + @$(ECHO) Full Target.. $(FULL_TARGET) + @$(ECHO) SourceSuffix. $(SOURCESUFFIX) + @$(ECHO) TargetSuffix. $(TARGETSUFFIX) + @$(ECHO) + @$(ECHO) == Directory info == + @$(ECHO) + @$(ECHO) Required pkgs... $(REQUIRE_PACKAGES) + @$(ECHO) + @$(ECHO) Basedir......... $(BASEDIR) + @$(ECHO) FPCDir.......... $(FPCDIR) + @$(ECHO) CrossBinDir..... $(CROSSBINDIR) + @$(ECHO) UnitsDir........ $(UNITSDIR) + @$(ECHO) PackagesDir..... $(PACKAGESDIR) + @$(ECHO) + @$(ECHO) GCC library..... $(GCCLIBDIR) + @$(ECHO) Other library... $(OTHERLIBDIR) + @$(ECHO) + @$(ECHO) == Tools info == + @$(ECHO) + @$(ECHO) As........ $(AS) + @$(ECHO) Ld........ $(LD) + @$(ECHO) Ar........ $(AR) + @$(ECHO) Rc........ $(RC) + @$(ECHO) + @$(ECHO) Mv........ $(MVPROG) + @$(ECHO) Cp........ $(CPPROG) + @$(ECHO) Rm........ $(RMPROG) + @$(ECHO) GInstall.. $(GINSTALL) + @$(ECHO) Echo...... $(ECHO) + @$(ECHO) Shell..... $(SHELL) + @$(ECHO) Date...... $(DATE) + @$(ECHO) FPCMake... $(FPCMAKE) + @$(ECHO) PPUMove... $(PPUMOVE) + @$(ECHO) Upx....... $(UPXPROG) + @$(ECHO) Zip....... $(ZIPPROG) + @$(ECHO) + @$(ECHO) == Object info == + @$(ECHO) + @$(ECHO) Target Loaders........ $(TARGET_LOADERS) + @$(ECHO) Target Units.......... $(TARGET_UNITS) + @$(ECHO) Target Implicit Units. $(TARGET_IMPLICITUNITS) + @$(ECHO) Target Programs....... $(TARGET_PROGRAMS) + @$(ECHO) Target Dirs........... $(TARGET_DIRS) + @$(ECHO) Target Examples....... $(TARGET_EXAMPLES) + @$(ECHO) Target ExampleDirs.... $(TARGET_EXAMPLEDIRS) + @$(ECHO) + @$(ECHO) Clean Units......... $(CLEAN_UNITS) + @$(ECHO) Clean Files......... $(CLEAN_FILES) + @$(ECHO) + @$(ECHO) Install Units....... $(INSTALL_UNITS) + @$(ECHO) Install Files....... $(INSTALL_FILES) + @$(ECHO) + @$(ECHO) == Install info == + @$(ECHO) + @$(ECHO) DateStr.............. $(DATESTR) + @$(ECHO) ZipName.............. $(ZIPNAME) + @$(ECHO) ZipPrefix............ $(ZIPPREFIX) + @$(ECHO) ZipCrossPrefix....... $(ZIPCROSSPREFIX) + @$(ECHO) ZipSuffix............ $(ZIPSUFFIX) + @$(ECHO) FullZipName.......... $(FULLZIPNAME) + @$(ECHO) Install FPC Package.. $(INSTALL_FPCPACKAGE) + @$(ECHO) + @$(ECHO) Install base dir..... $(INSTALL_BASEDIR) + @$(ECHO) Install binary dir... $(INSTALL_BINDIR) + @$(ECHO) Install library dir.. $(INSTALL_LIBDIR) + @$(ECHO) Install units dir.... $(INSTALL_UNITDIR) + @$(ECHO) Install source dir... $(INSTALL_SOURCEDIR) + @$(ECHO) Install doc dir...... $(INSTALL_DOCDIR) + @$(ECHO) Install example dir.. $(INSTALL_EXAMPLEDIR) + @$(ECHO) Install data dir..... $(INSTALL_DATADIR) + @$(ECHO) + @$(ECHO) Dist destination dir. $(DIST_DESTDIR) + @$(ECHO) Dist zip name........ $(DIST_ZIPNAME) + @$(ECHO) +.PHONY: fpc_info +fpc_info: $(INFORULES) +.PHONY: fpc_makefile fpc_makefiles fpc_makefile_sub1 fpc_makefile_sub2 \ + fpc_makefile_dirs +fpc_makefile: + $(FPCMAKE) -w -T$(OS_TARGET) Makefile.fpc +fpc_makefile_sub1: +ifdef TARGET_DIRS + $(FPCMAKE) -w -T$(OS_TARGET) $(addsuffix /Makefile.fpc,$(TARGET_DIRS)) +endif +ifdef TARGET_EXAMPLEDIRS + $(FPCMAKE) -w -T$(OS_TARGET) $(addsuffix /Makefile.fpc,$(TARGET_EXAMPLEDIRS)) +endif +fpc_makefile_sub2: $(addsuffix _makefile_dirs,$(TARGET_DIRS) $(TARGET_EXAMPLEDIRS)) +fpc_makefile_dirs: fpc_makefile_sub1 fpc_makefile_sub2 +fpc_makefiles: fpc_makefile fpc_makefile_dirs +all: fpc_all +debug: fpc_debug +smart: fpc_smart +release: fpc_release +units: fpc_units +examples: +shared: fpc_shared +install: fpc_install +sourceinstall: fpc_sourceinstall +exampleinstall: fpc_exampleinstall +distinstall: +zipinstall: +zipsourceinstall: +zipexampleinstall: +zipdistinstall: +clean: fpc_clean +distclean: fpc_distclean +cleanall: fpc_cleanall +info: fpc_info +makefiles: fpc_makefiles +.PHONY: all debug smart release units examples shared install sourceinstall exampleinstall distinstall zipinstall zipsourceinstall zipexampleinstall zipdistinstall clean distclean cleanall info makefiles +ifneq ($(wildcard fpcmake.loc),) +include fpcmake.loc +endif diff --git a/utils/fpcreslipo/Makefile.fpc b/utils/fpcreslipo/Makefile.fpc new file mode 100644 index 0000000000..52e818274e --- /dev/null +++ b/utils/fpcreslipo/Makefile.fpc @@ -0,0 +1,21 @@ +# +# Makefile.fpc for FPCMake +# + +[target] +programs=fpcreslipo +units=msghandler paramparser sourcehandler + +[clean] +units=fpcresfix elfbfd elfres + +[require] +packages=rtl fcl-res + +[install] +fpcpackage=y + +[default] +fpcdir=../.. + +[rules] diff --git a/utils/fpcreslipo/fpcreslipo.pp b/utils/fpcreslipo/fpcreslipo.pp new file mode 100644 index 0000000000..0a9acc4cd2 --- /dev/null +++ b/utils/fpcreslipo/fpcreslipo.pp @@ -0,0 +1,271 @@ +{ + + FPCResLipo - Free Pascal External Resource Thinner + Part of the Free Pascal distribution + Copyright (C) 2008 by Giulio Bernardi + + See the file COPYING, included in this distribution, + for details about the copyright. + + This program is distributed in the hope that it will be useful, + but WITHOUT ANY WARRANTY; without even the implied warranty of + MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. +} + +program fpcreslipo; + +{$MODE OBJFPC} {$H+} + +uses + SysUtils, Classes, paramparser, msghandler, sourcehandler, + resource, externalreader, externalwriter; + +const + halt_no_err = 0; + halt_param_err = 1; + halt_read_err = 2; + halt_write_err = 3; + + progname = 'fpcreslipo'; + progversion = '1.0'; + + fpcversion = {$INCLUDE %FPCVERSION%}; + host_arch = {$INCLUDE %FPCTARGETCPU%}; + host_os = {$INCLUDE %FPCTARGETOS%}; + build_date = {$INCLUDE %DATE%}; + +var + params : TParameters = nil; + sourcefiles : TSourceFiles = nil; + outResources : TResources = nil; + +procedure ShowVersion; +begin + writeln(progname+' - external resource file thinner, version '+progversion+' ['+build_date+'], FPC '+fpcversion); + writeln('Host platform: '+host_os+' - '+host_arch); + writeln('Copyright (c) 2008 by Giulio Bernardi.'); +end; + +procedure ShowHelp; +begin + ShowVersion; + writeln('Syntax: '+progname+' [options] <inputfile> [<inputfile>...] -o <outputfile>'); + writeln; + writeln('Options:'); + writeln(' --help, -h, -? Show this screen.'); + writeln(' --version, -V Show program version.'); + writeln(' --verbose, -v Be verbose.'); + writeln(' --output, -o <x> Set the output file name.'); + writeln(' --endian, -e <x> Set shared file endianess (big, little)'); + writeln(' default is big'); + writeln; + writeln('Example:'); + writeln(' '+progname+' myprog.i386.fpcres myprog.powerpc.fpcres -o myprog.fpcres'); + writeln; + writeln(' strips common resources from the two input files and puts them in the'); + writeln(' output file'); +end; + +const + SOutputFileAlreadySet = 'Output file name already set.'; + SUnknownParameter = 'Unknown parameter ''%s'''; + SArgumentMissing = 'Argument missing for option ''%s'''; + SUnknownEndianess = 'Unknown endianess ''%s'''; + SNoInputFiles = 'No input files'; + STooFewInputFiles = 'At least two input files must be specified'; + SNoOutputFile = 'No output file name specified'; + SCantOpenFile = 'Can''t open file ''%s'''; + SUnknownInputFormat = 'No known file format detected for file ''%s'''; + SCantCreateFile = 'Can''t create file ''%s'''; + +function GetCurrentTimeMsec : longint; +var h,m,s,ms : word; +begin + DecodeTime(Time,h,m,s,ms); + Result:=h*3600*1000 + m*60*1000 + s*1000 + ms; +end; + +procedure CheckInputFiles; +begin + if params.InputFiles.Count<2 then + begin + case params.InputFiles.Count of + 0 : Messages.DoError(SNoInputFiles); + 1 : Messages.DoError(STooFewInputFiles); + end; + halt(halt_param_err); + end; +end; + +procedure CheckOutputFile; +begin + if params.OutputFile<>'' then exit; + Messages.DoError(SNoOutputFile); + halt(halt_param_err); +end; + +procedure ParseParams; +var msg : string; +begin + Messages.DoVerbose('parsing command line parameters'); + msg:=''; + if ParamCount = 0 then + begin + ShowHelp; + halt(halt_no_err); + end; + params:=TParameters.Create; + try + params.Parse; + except + on e : EOutputFileAlreadySetException do msg:=SOutputFileAlreadySet; + on e : EUnknownParameterException do msg:=Format(SUnknownParameter,[e.Message]); + on e : EArgumentMissingException do msg:=Format(SArgumentMissing,[e.Message]); + on e : EUnknownEndianessException do msg:=Format(SUnknownEndianess,[e.Message]); + end; + Messages.Verbose:=params.Verbose; + if msg<>'' then + begin + Messages.DoError(msg); + halt(halt_param_err); + end; + if params.Version then + begin + ShowVersion; + halt(halt_no_err); + end; + if params.Help then + begin + ShowHelp; + halt(halt_no_err); + end; + + CheckInputFiles; + CheckOutputFile; + + Messages.DoVerbose('finished parsing command line parameters'); +end; + +procedure LoadSourceFiles; +var msg : string; + i : integer; +begin + msg:=''; + sourcefiles:=TSourceFiles.Create; + try + for i:=0 to params.InputFiles.Count-1 do + sourcefiles.NewSourceFile(params.InputFiles[i]); + except + on e : ECantOpenFileException do msg:=Format(SCantOpenFile,[e.Message]); + on e : EUnknownInputFormatException do msg:=Format(SUnknownInputFormat,[e.Message]); + on e : Exception do + begin + if e.Message='' then msg:=e.ClassName + else msg:=e.Message; + end; + end; + if msg<>'' then + begin + Messages.DoError(msg); + halt(halt_read_err); + end; +end; + +procedure ProcessFiles; +begin + Messages.DoVerbose('processing input files...'); + outResources:=TResources.Create; + sourcefiles.Process(outResources); + Messages.DoVerbose('input files processed.'); +end; + +function WriteOutputFile : boolean; +var aStream : TFileStream; + aWriter : TExternalResourceWriter; + msg : string; +begin + if outResources.Count=0 then + begin + Result:=false; + Messages.DoVerbose('Nothing to do'); + exit; + end; + Result:=true; + Messages.DoVerbose(Format('Trying to create file %s...',[params.OutputFile])); + try + aStream:=TFileStream.Create(params.OutputFile,fmCreate or fmShareDenyWrite); + except + Messages.DoError(Format(SCantCreateFile,[params.OutputFile])); + halt(halt_write_err); + end; + try + aWriter:=TExternalResourceWriter.Create; + aWriter.Endianess:=params.Endianess; + try + try + outResources.WriteToStream(aStream,aWriter); + except + on e : Exception do + begin + if e.Message='' then msg:=e.ClassName + else msg:=e.Message; + Messages.DoError(msg); + halt(halt_write_err); + end; + end; + Messages.DoVerbose(Format('%d resources written.',[outResources.Count])); + Messages.DoVerbose(Format('File %s written',[params.OutputFile])); + finally + aWriter.Free; + end; + finally + aStream.Free; + end; + FreeAndNil(outResources); +end; + +procedure UpdateFiles; +var msg : string; +begin + try + sourcefiles.Update; + except + on e : ECantCreateFileException do msg:=Format(SCantCreateFile,[e.Message]); + on e : Exception do + begin + if e.Message='' then msg:=e.ClassName + else msg:=e.Message; + end; + end; + if msg<>'' then + begin + Messages.DoError(msg); + halt(halt_write_err); + end; +end; + +procedure Cleanup; +begin + Messages.DoVerbose('Cleaning up'); + if OutResources<>nil then OutResources.Free; + if SourceFiles<>nil then SourceFiles.Free; + if Params<>nil then Params.Free; +end; + +var before, elapsed : longint; + +begin + try + before:=GetCurrentTimeMsec; + ParseParams; + LoadSourceFiles; + ProcessFiles; + if WriteOutputFile then + UpdateFiles; + elapsed:=GetCurrentTimeMsec-before; + if elapsed<0 then elapsed:=24*3600*1000 + elapsed; + Messages.DoVerbose(Format('Time elapsed: %d.%d seconds',[elapsed div 1000,(elapsed mod 1000) div 10])); + finally + Cleanup; + end; +end. diff --git a/utils/fpcreslipo/msghandler.pp b/utils/fpcreslipo/msghandler.pp new file mode 100644 index 0000000000..17baf20e14 --- /dev/null +++ b/utils/fpcreslipo/msghandler.pp @@ -0,0 +1,105 @@ +{ + + FPCResLipo - Free Pascal External Resource Thinner + Part of the Free Pascal distribution + Copyright (C) 2008 by Giulio Bernardi + + Output messages handler + + See the file COPYING, included in this distribution, + for details about the copyright. + + This program is distributed in the hope that it will be useful, + but WITHOUT ANY WARRANTY; without even the implied warranty of + MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. +} + +unit msghandler; + +{$MODE OBJFPC} + +interface + +uses + Classes, SysUtils; + +type + + { TMessages } + + TMessages = class + private + fVerboseSet : boolean; + fVerbose : boolean; + fVerbCache : TStringList; + fStdOut : text; + fStdErr : text; + procedure SetVerbose(const aValue : boolean); + protected + public + constructor Create; + destructor Destroy; override; + procedure DoError(const aMsg : string); + procedure DoVerbose(const aMsg : string); + property Verbose : boolean read fVerbose write SetVerbose; + end; + +var Messages : TMessages; + +implementation + +{ TMessages } + +procedure TMessages.SetVerbose(const aValue: boolean); +var i : integer; +begin + fVerbose:=aValue; + if fVerboseSet then exit; + + fVerboseSet:=true; + if fVerbose then //output all verbose messages we didn't output before + for i:=0 to fVerbCache.Count-1 do + writeln(fStdOut,'Debug: '+fVerbCache[i]); + + FreeAndNil(fVerbCache); +end; + +constructor TMessages.Create; +begin + fVerbose:=false; + fVerboseSet:=false; + fVerbCache:=TStringList.Create; + fStdOut:=stdout; + fStdErr:=stderr; +end; + +destructor TMessages.Destroy; +begin + if fVerbCache<>nil then + fVerbCache.Free; +end; + +procedure TMessages.DoError(const aMsg: string); +begin + writeln(fStdErr,'Error: '+aMsg); +end; + +procedure TMessages.DoVerbose(const aMsg: string); +begin + if not fVerboseSet then + begin + fVerbCache.Add(aMsg); + exit; + end; + if fVerbose then + writeln(fStdOut,'Debug: '+aMsg); +end; + +initialization + Messages:=TMessages.Create; + + +finalization + Messages.Free; + +end. diff --git a/utils/fpcreslipo/paramparser.pp b/utils/fpcreslipo/paramparser.pp new file mode 100644 index 0000000000..f1d0ac9450 --- /dev/null +++ b/utils/fpcreslipo/paramparser.pp @@ -0,0 +1,187 @@ +{ + + FPCResLipo - Free Pascal External Resource Thinner + Part of the Free Pascal distribution + Copyright (C) 2008 by Giulio Bernardi + + Handles the parsing of parameters + + See the file COPYING, included in this distribution, + for details about the copyright. + + This program is distributed in the hope that it will be useful, + but WITHOUT ANY WARRANTY; without even the implied warranty of + MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. +} + +unit paramparser; + +{$MODE OBJFPC} {$H+} + +interface + +uses + Classes, SysUtils, externaltypes; + +type + EParametersException = class(Exception); + EOutputFileAlreadySetException = class(EParametersException); + EUnknownParameterException = class(EParametersException); + EArgumentMissingException = class(EParametersException); + EUnknownEndianessException = class(EParametersException); + +type + + { TParameters } + + TParameters = class + private + fHelp : boolean; + fVersion : boolean; + fVerbose : boolean; + fInputFiles : TStringList; + fOutputFile : string; + fEndianess : byte; + + procedure ParseOutputFile(aList : TStringList; var index : integer; const parname : string); + procedure ParseEndianess(aList : TStringList; var index : integer; const parname : string); + function DoOptionalArgument(aList : TStringList; const i : integer) : string; + function DoMandatoryArgument(aList : TStringList; const i : integer) : string; + function IsParameter(const s : string) : boolean; + function ParamsToStrList : TStringList; + protected + public + constructor Create; + destructor Destroy; override; + procedure Parse; + property Help : boolean read fHelp; + property Version : boolean read fVersion; + property Verbose : boolean read fVerbose; + property InputFiles : TStringList read fInputFiles; + property OutputFile : string read fOutputFile write fOutputFile; + property Endianess : byte read fEndianess write fEndianess; + end; + +implementation + +uses + msghandler; + +{ TParameters } + +procedure TParameters.ParseOutputFile(aList: TStringList; var index: integer; + const parname : string); +begin + if fOutputFile<>'' then + raise EOutputFileAlreadySetException.Create(''); + inc(index); + fOutputFile:=DoMandatoryArgument(aList,index); + if fOutputFile='' then + raise EArgumentMissingException.Create(parname); +end; + +procedure TParameters.ParseEndianess(aList: TStringList; var index: integer; + const parname: string); +var tmp : string; +begin + inc(index); + tmp:=LowerCase(DoMandatoryArgument(aList,index)); + if tmp='' then + raise EArgumentMissingException.Create(parname); + + if tmp='big' then fEndianess:=EXT_ENDIAN_BIG + else if tmp='little' then fEndianess:=EXT_ENDIAN_LITTLE + else raise EUnknownEndianessException.Create(tmp); +end; + +function TParameters.DoOptionalArgument(aList: TStringList; const i: integer + ): string; +begin + Result:=''; + if aList.Count>i then + begin + if not IsParameter(aList[i]) then + Result:=aList[i]; + end; +end; + +function TParameters.DoMandatoryArgument(aList: TStringList; const i: integer + ): string; +begin + Result:=''; + if aList.count>i then + Result:=aList[i]; +end; + +function TParameters.IsParameter(const s: string): boolean; +begin + Result:=false; + if length(s)<=1 then exit; + if copy(s,1,1)='-' then Result:=true; +end; + +function TParameters.ParamsToStrList: TStringList; +var i : integer; +begin + Result:=TStringList.Create; + try + for i:=1 to ParamCount do + Result.Add(ParamStr(i)); + except + Result.Free; + raise; + end; +end; + +procedure TParameters.Parse; +var fList : TStringList; + tmp : string; + i : integer; +begin + fList:=ParamsToStrList; + try + i:=0; + while i<fList.Count do + begin + tmp:=fList[i]; + Messages.DoVerbose(Format('parsing parameter ''%s''',[tmp])); + if IsParameter(tmp) then + begin + if ((tmp='--help') or (tmp='-h') or (tmp='-?')) then + fHelp:=true + else if ((tmp='--version') or (tmp='-V')) then + fVersion:=true + else if ((tmp='--verbose') or (tmp='-v')) then + fVerbose:=true + else if ((tmp='-o') or (tmp='--output')) then + ParseOutputFile(fList,i,tmp) + else if ((tmp='-e') or (tmp='--endian')) then + ParseEndianess(fList,i,tmp) + else + raise EUnknownParameterException.Create(tmp); + end + else + fInputFiles.Add(tmp); //assume it is an input file + inc(i); + end; + finally + fList.Free; + end; +end; + +constructor TParameters.Create; +begin + fHelp:=false; + fVersion:=false; + fVerbose:=false; + fInputFiles:=TStringList.Create; + fOutputFile:=''; + fEndianess:=EXT_ENDIAN_BIG; +end; + +destructor TParameters.Destroy; +begin + fInputFiles.Free; +end; + +end. diff --git a/utils/fpcreslipo/sourcehandler.pp b/utils/fpcreslipo/sourcehandler.pp new file mode 100644 index 0000000000..4cac365e8c --- /dev/null +++ b/utils/fpcreslipo/sourcehandler.pp @@ -0,0 +1,341 @@ +{ + + FPCResLipo - Free Pascal External Resource Thinner + Part of the Free Pascal distribution + Copyright (C) 2008 by Giulio Bernardi + + Source files handling + + See the file COPYING, included in this distribution, + for details about the copyright. + + This program is distributed in the hope that it will be useful, + but WITHOUT ANY WARRANTY; without even the implied warranty of + MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. +} + +unit sourcehandler; + +{$MODE OBJFPC} {$H+} + +interface + +uses + Classes, SysUtils, resource, externalreader, externalwriter; + +type + ESourceFilesException = class(Exception); + ECantOpenFileException = class(ESourceFilesException); + EUnknownInputFormatException = class(ESourceFilesException); + ECantCreateFileException = class(ESourceFilesException); + +type + + { TSourceFile } + + TSourceFile = class + private + fFname : string; + fStream : TStream; + fResources : TResources; + fProcessed : TResources; + fEndianess : byte; + fModified : boolean; + function Delete : boolean; + protected + public + constructor Create(aFileName : string); + destructor Destroy; override; + procedure Update; + property FileName : string read fFname; + property Resources : TResources read fResources; + property Processed : TResources read fProcessed; + property Endianess : byte read fEndianess; + property Modified : boolean read fModified write fModified; + end; + + { TSourceFiles } + + TSourceFiles = class + private + similarities, simcount : array of integer; + fList : TFPList; + function GetItem(index : integer) : TSourceFile; + function GetCount : integer; + procedure ResetSimArrays; + function GetMostCommon : integer; + procedure CheckSimilarities(idx : integer; aType,aName : TResourceDesc; aLangID : TLangID); + procedure ExtractCommon(idx : integer; outRes : TResources; aType,aName : TResourceDesc; aLangID : TLangID); + protected + public + constructor Create; + destructor Destroy; override; + procedure NewSourceFile(aFileName : string); + procedure Process(outRes : TResources); + procedure Update; + property Items[index : integer] : TSourceFile read GetItem; + property Count : integer read GetCount; + end; + +implementation + +uses msghandler; + +{ TSourceFile } + +function TSourceFile.Delete : boolean; +begin + FreeAndNil(fResources); + FreeAndNil(fStream); + Result:=DeleteFile(fFname); + if not Result then + Messages.DoError(Format('Can''t delete file %s.',[fFname])) +end; + +constructor TSourceFile.Create(aFileName: string); +var aReader : TExternalResourceReader; +begin + fModified:=false; + fFName:=aFileName; + Messages.DoVerbose(Format('Trying to open file %s...',[fFName])); + try + fStream:=TFileStream.Create(fFName,fmOpenRead or fmShareDenyWrite); + except + raise ECantOpenFileException.Create(fFName); + end; + aReader:=TExternalResourceReader.Create; + fResources:=TResources.Create; + try + try + try + Messages.DoVerbose('Reading resource information...'); + fResources.LoadFromStream(fStream,aReader); + Messages.DoVerbose(Format('%d resources read.',[fResources.Count])); + fEndianess:=aReader.Endianess; + except + on e : EResourceReaderWrongFormatException do + raise EUnknownInputFormatException.Create(fFname); + end; + except + FreeAndNil(fResources); + FreeAndNil(fStream); + end; + finally + aReader.Free; + end; + fProcessed:=TResources.Create; +end; + +destructor TSourceFile.Destroy; +begin + if fResources<>nil then fResources.Free; + if fProcessed<>nil then fProcessed.Free; + if fStream<>nil then fStream.Free; +end; + +procedure TSourceFile.Update; +var tmp : string; + aWriter : TExternalResourceWriter; + aStream : TFileStream; +begin + if not fModified then + begin + Messages.DoVerbose(Format('File %s is unchanged.',[fFname])); + exit; + end; + if Resources.Count=0 then + begin + if Delete then + Messages.DoVerbose(Format('No more resources in file %s, deleted',[fFname])); + exit; + end; + + tmp:=ExtractFileDir(fFname); + if tmp='' then tmp:='.'; + tmp:=GetTempFileName(tmp,'tmp'); + + Messages.DoVerbose(Format('Updating file %s...',[fFname])); + try + aStream:=TFileStream.Create(tmp,fmCreate or fmShareDenyWrite); + except + raise ECantCreateFileException.Create(tmp); + end; + try + aWriter:=TExternalResourceWriter.Create; + aWriter.Endianess:=Endianess; + try + Resources.WriteToStream(aStream,aWriter); + Messages.DoVerbose(Format('%d resources written.',[Resources.Count])); + finally + aWriter.Free; + end; + finally + aStream.Free; + end; + + if not Delete then exit; + if not RenameFile(tmp,fFname) then + Messages.DoError(Format('Can''t rename file %s to %s.',[tmp,fFname])) + else + Messages.DoVerbose(Format('File %s updated',[fFname])); +end; + +{ TSourceFiles } + +function TSourceFiles.GetItem(index : integer) : TSourceFile; +begin + Result:=TSourceFile(fList[index]); +end; + +function TSourceFiles.GetCount: integer; +begin + Result:=fList.Count; +end; + +procedure TSourceFiles.ResetSimArrays; +var i : integer; +begin + for i:=0 to Count-1 do + begin + similarities[i]:=i; + simcount[i]:=1; + end; +end; + +function TSourceFiles.GetMostCommon: integer; +var i : integer; + max, maxidx : integer; +begin + max:=0; + maxidx:=0; + for i:=0 to Count-1 do + if simcount[i]>max then + begin + max:=simcount[i]; + maxidx:=i; + end; + Result:=maxidx; +end; + +procedure TSourceFiles.CheckSimilarities(idx: integer; aType, + aName: TResourceDesc; aLangID: TLangID); +var i,j : integer; + res1, res2 : TAbstractResource; +begin + for i:=idx to Count-1 do + begin + if similarities[i]<>i then continue; + try + res1:=Items[i].Resources.Find(aType,aName,aLangID); + except + on e : EResourceNotFoundException do continue; + end; + for j:=idx+1 to Count-1 do + begin + try + res2:=Items[j].Resources.Find(aType,aName,aLangID); + except + on e : EResourceNotFoundException do continue; + end; + if res1.CompareContents(res2) then + begin + dec(simcount[similarities[j]]); + inc(simcount[similarities[i]]); + similarities[j]:=similarities[i]; + end; + end; + end; +end; + +procedure TSourceFiles.ExtractCommon(idx: integer; outRes: TResources; aType, + aName: TResourceDesc; aLangID: TLangID); +var maxidx,i : integer; + res : TAbstractResource; +begin + maxidx:=GetMostCommon; + if simcount[maxidx]<=1 then + begin + for i:=idx to Count-1 do + begin + try + res:=Items[i].Resources.Remove(aType,aName,aLangID); + except + on e : EResourceNotFoundException do continue; + end; + Items[i].Processed.Add(res); + end; + exit; + end; + + res:=Items[maxidx].Resources.Remove(aType,aName,aLangID); + Items[maxidx].Modified:=true; + outRes.Add(res); + for i:=idx to Count-1 do + begin + if i=maxidx then continue; + try + res:=Items[i].Resources.Remove(aType,aName,aLangID); + except + on e : EResourceNotFoundException do continue; + end; + if similarities[i]=similarities[maxidx] then + begin + res.Free; + Items[i].Modified:=true; + end + else + Items[i].Processed.Add(res); + end; +end; + +constructor TSourceFiles.Create; +begin + fList:=TFPList.Create; +end; + +destructor TSourceFiles.Destroy; +var i : integer; +begin + for i:=0 to fList.Count-1 do + TSourceFile(fList[i]).Free; + fList.Free; +end; + +procedure TSourceFiles.NewSourceFile(aFileName : string); +var aFile : TSourceFile; +begin + aFile:=TSourceFile.Create(aFileName); + fList.Add(aFile); +end; + +procedure TSourceFiles.Process(outRes: TResources); +var i : integer; + res : TAbstractResource; +begin + setlength(similarities,Count); + setlength(simcount,Count); + for i:=0 to Count-1 do + begin + while Items[i].Resources.Count>0 do + begin + ResetSimArrays; + res:=Items[i].Resources[Items[i].Resources.Count-1]; + if res.Owner<>nil then + res:=res.Owner; + + CheckSimilarities(i,res._Type,res.Name,res.LangID); + ExtractCommon(i,outRes,res._Type,res.Name,res.LangID); + end; + Items[i].Resources.MoveFrom(Items[i].Processed); + end; +end; + +procedure TSourceFiles.Update; +var i : integer; +begin + for i:=0 to Count-1 do + Items[i].Update; +end; + +end. + |