|
@@ -1,5 +1,5 @@
|
|
|
#
|
|
|
-# Makefile generated by fpcmake v0.99.13 on 2000/01/10 16:42
|
|
|
+# Makefile generated by fpcmake v0.99.13 [2000/01/10]
|
|
|
#
|
|
|
|
|
|
defaultrule: all
|
|
@@ -52,13 +52,31 @@ else
|
|
|
EXEEXT=.exe
|
|
|
endif
|
|
|
|
|
|
-# The path which is search separated by spaces
|
|
|
+# The path which is searched separated by spaces
|
|
|
ifdef inlinux
|
|
|
SEARCHPATH=$(subst :, ,$(PATH))
|
|
|
else
|
|
|
SEARCHPATH=$(subst ;, ,$(PATH))
|
|
|
endif
|
|
|
|
|
|
+# echo
|
|
|
+ifndef ECHO
|
|
|
+ECHO:=$(strip $(wildcard $(addsuffix /echo$(EXEEXT),$(SEARCHPATH))))
|
|
|
+ifeq ($(ECHO),)
|
|
|
+ECHO:=echo
|
|
|
+else
|
|
|
+ECHO:=$(firstword $(ECHO))
|
|
|
+endif
|
|
|
+endif
|
|
|
+export ECHO
|
|
|
+
|
|
|
+# Base dir
|
|
|
+ifdef PWD
|
|
|
+BASEDIR:=$(shell $(PWD))
|
|
|
+else
|
|
|
+BASEDIR=.
|
|
|
+endif
|
|
|
+
|
|
|
#####################################################################
|
|
|
# FPC version/target Detection
|
|
|
#####################################################################
|
|
@@ -67,66 +85,86 @@ endif
|
|
|
ifndef FPC
|
|
|
# Compatibility with old makefiles
|
|
|
ifdef PP
|
|
|
-export FPC=$(PP)
|
|
|
+FPC=$(PP)
|
|
|
else
|
|
|
ifdef inOS2
|
|
|
-export FPC=ppos2$(EXEEXT)
|
|
|
+FPC=ppos2$(EXEEXT)
|
|
|
else
|
|
|
-export FPC=ppc386$(EXEEXT)
|
|
|
+FPC=ppc386$(EXEEXT)
|
|
|
endif
|
|
|
endif
|
|
|
endif
|
|
|
|
|
|
# Target OS
|
|
|
ifndef OS_TARGET
|
|
|
-export OS_TARGET:=$(shell $(FPC) -iTO)
|
|
|
+OS_TARGET:=$(shell $(FPC) -iTO)
|
|
|
endif
|
|
|
|
|
|
# Source OS
|
|
|
ifndef OS_SOURCE
|
|
|
-export OS_SOURCE:=$(shell $(FPC) -iSO)
|
|
|
+OS_SOURCE:=$(shell $(FPC) -iSO)
|
|
|
endif
|
|
|
|
|
|
# Target CPU
|
|
|
ifndef CPU_TARGET
|
|
|
-export CPU_TARGET:=$(shell $(FPC) -iTP)
|
|
|
+CPU_TARGET:=$(shell $(FPC) -iTP)
|
|
|
endif
|
|
|
|
|
|
# Source CPU
|
|
|
ifndef CPU_SOURCE
|
|
|
-export CPU_SOURCE:=$(shell $(FPC) -iSP)
|
|
|
+CPU_SOURCE:=$(shell $(FPC) -iSP)
|
|
|
endif
|
|
|
|
|
|
# FPC version
|
|
|
ifndef FPC_VERSION
|
|
|
-export FPC_VERSION:=$(shell $(FPC) -iV)
|
|
|
+FPC_VERSION:=$(shell $(FPC) -iV)
|
|
|
endif
|
|
|
|
|
|
+export FPC OS_TARGET OS_SOURCE CPU_TARGET CPU_SOURCE FPC_VERSION
|
|
|
+
|
|
|
#####################################################################
|
|
|
-# Default Settings
|
|
|
+# FPCDIR Setting
|
|
|
#####################################################################
|
|
|
|
|
|
-# Release ? Then force OPT and don't use extra opts via commandline
|
|
|
-ifndef REDIRFILE
|
|
|
-REDIRFILE=log
|
|
|
+# Test FPCDIR to look if the RTL dir exists
|
|
|
+ifdef FPCDIR
|
|
|
+override FPCDIR:=$(subst \,/,$(FPCDIR))
|
|
|
+ifeq ($(wildcard $(FPCDIR)/rtl),)
|
|
|
+override FPCDIR=wrong
|
|
|
+endif
|
|
|
+else
|
|
|
+override FPCDIR=wrong
|
|
|
endif
|
|
|
|
|
|
-ifdef RELEASE
|
|
|
-override OPT:=-Xs -OG2p3 -n
|
|
|
+# Default FPCDIR
|
|
|
+ifeq ($(FPCDIR),wrong)
|
|
|
+override FPCDIR=../..
|
|
|
+ifeq ($(wildcard $(FPCDIR)/rtl),)
|
|
|
+override FPCDIR=wrong
|
|
|
+endif
|
|
|
endif
|
|
|
|
|
|
-# Verbose settings (warning,note,info)
|
|
|
-ifdef VERBOSE
|
|
|
-override OPT+=-vwni
|
|
|
+# Detect FPCDIR
|
|
|
+ifeq ($(FPCDIR),wrong)
|
|
|
+ifdef inlinux
|
|
|
+override FPCDIR=/usr/lib/fpc/$(FPC_VERSION)
|
|
|
+else
|
|
|
+override FPCDIR:=$(subst /$(FPC)$(EXEEXT),,$(firstword $(strip $(wildcard $(addsuffix /$(FPC)$(EXEEXT),$(SEARCHPATH))))))
|
|
|
+endif
|
|
|
endif
|
|
|
|
|
|
-ifdef REDIR
|
|
|
-ifndef inlinux
|
|
|
-override FPC=redir -eo $(FPC)
|
|
|
+ifndef PACKAGESDIR
|
|
|
+PACKAGESDIR=$(FPCDIR)/packages
|
|
|
endif
|
|
|
-# set the verbosity to max
|
|
|
-override OPT+=-va
|
|
|
-override REDIR:= >> $(REDIRFILE)
|
|
|
+ifndef TOOLKITSDIR
|
|
|
+TOOLKITSDIR=
|
|
|
+endif
|
|
|
+ifndef COMPONENTSDIR
|
|
|
+COMPONENTSDIR=
|
|
|
+endif
|
|
|
+# Create units dir
|
|
|
+ifneq ($(FPCDIR),.)
|
|
|
+UNITSDIR=$(FPCDIR)/units/$(OS_TARGET)
|
|
|
endif
|
|
|
|
|
|
#####################################################################
|
|
@@ -151,18 +189,10 @@ ZIPTARGET=install
|
|
|
|
|
|
# Directories
|
|
|
|
|
|
-ifndef FPCDIR
|
|
|
-FPCDIR=../..
|
|
|
-endif
|
|
|
-ifndef PACKAGEDIR
|
|
|
-PACKAGEDIR=$(FPCDIR)/packages
|
|
|
-endif
|
|
|
-ifndef COMPONENTDIR
|
|
|
-COMPONENTDIR=$(FPCDIR)/components
|
|
|
-endif
|
|
|
|
|
|
# Packages
|
|
|
|
|
|
+override PACKAGES+=rtl
|
|
|
|
|
|
# Libraries
|
|
|
|
|
@@ -171,40 +201,59 @@ endif
|
|
|
|
|
|
INFOTARGET=fpc_infocfg fpc_infoobjects fpc_infoinstall
|
|
|
|
|
|
-#####################################################################
|
|
|
-# Default Directories
|
|
|
-#####################################################################
|
|
|
|
|
|
-# Base dir
|
|
|
-ifdef PWD
|
|
|
-BASEDIR:=$(shell $(PWD))
|
|
|
-else
|
|
|
-BASEDIR=.
|
|
|
+# Package/component dirs
|
|
|
+
|
|
|
+# Check if the dirs really exists, else turn it off
|
|
|
+ifeq ($(wildcard $(UNITSDIR)),)
|
|
|
+UNITSDIR=
|
|
|
+endif
|
|
|
+ifeq ($(wildcard $(TOOLKITSDIR)),)
|
|
|
+TOOLKITSDIR=
|
|
|
+endif
|
|
|
+ifeq ($(wildcard $(PACKAGESDIR)),)
|
|
|
+PACKAGESDIR=
|
|
|
+endif
|
|
|
+ifeq ($(wildcard $(COMPONENTSDIR)),)
|
|
|
+COMPONENTSDIR=
|
|
|
endif
|
|
|
|
|
|
-# this can be set to 'rtl' when the RTL units are installed
|
|
|
-ifndef UNITPREFIX
|
|
|
-UNITPREFIX=units
|
|
|
+ifneq ($(wildcard $(FPCDIR)/rtl),)
|
|
|
+ifneq ($(wildcard $(FPCDIR)/rtl/$(OS_TARGET)),)
|
|
|
+PACKAGEDIR_RTL=$(FPCDIR)/rtl/$(OS_TARGET)
|
|
|
+else
|
|
|
+PACKAGEDIR_RTL=$(FPCDIR)/rtl
|
|
|
endif
|
|
|
+UNITDIR_RTL=$(PACKAGEDIR_RTL)
|
|
|
+else
|
|
|
+PACKAGEDIR_RTL=
|
|
|
+ifneq ($(wildcard $(UNITSDIR)/rtl),)
|
|
|
+ifneq ($(wildcard $(UNITSDIR)/rtl/$(OS_TARGET)),)
|
|
|
+UNITDIR_RTL=$(UNITSDIR)/rtl/$(OS_TARGET)
|
|
|
+else
|
|
|
+UNITDIR_RTL=$(UNITSDIR)/rtl
|
|
|
+endif
|
|
|
+else
|
|
|
+UNITDIR_RTL=
|
|
|
+endif
|
|
|
+endif
|
|
|
+ifdef UNITDIR_RTL
|
|
|
+override NEEDUNITDIR+=$(UNITDIR_RTL)
|
|
|
+endif
|
|
|
+
|
|
|
+#####################################################################
|
|
|
+# Default Directories
|
|
|
+#####################################################################
|
|
|
|
|
|
# set the prefix directory where to install everything
|
|
|
ifndef PREFIXINSTALLDIR
|
|
|
ifdef inlinux
|
|
|
-export PREFIXINSTALLDIR=/usr
|
|
|
+PREFIXINSTALLDIR=/usr
|
|
|
else
|
|
|
-export PREFIXINSTALLDIR=/pp
|
|
|
-endif
|
|
|
-endif
|
|
|
-
|
|
|
-# create fcldir,rtldir,unitdir
|
|
|
-ifdef FPCDIR
|
|
|
-override FPCDIR:=$(subst \,/,$(FPCDIR))
|
|
|
-ifneq ($(FPCDIR),.)
|
|
|
-override RTLDIR=$(FPCDIR)/rtl/$(OS_TARGET)
|
|
|
-override FCLDIR=$(FPCDIR)/fcl/$(OS_TARGET)
|
|
|
-override UNITSDIR=$(FPCDIR)/units/$(OS_TARGET)
|
|
|
+PREFIXINSTALLDIR=/pp
|
|
|
endif
|
|
|
endif
|
|
|
+export PREFIXINSTALLDIR
|
|
|
|
|
|
#####################################################################
|
|
|
# Install Directories
|
|
@@ -230,7 +279,10 @@ endif
|
|
|
|
|
|
# set the directory where to install the units.
|
|
|
ifndef UNITINSTALLDIR
|
|
|
-UNITINSTALLDIR=$(BASEINSTALLDIR)/$(UNITPREFIX)/$(OS_TARGET)
|
|
|
+UNITINSTALLDIR=$(BASEINSTALLDIR)/units/$(OS_TARGET)
|
|
|
+ifdef UNITSUBDIR
|
|
|
+UNITINSTALLDIR:=$(UNITINSTALLDIR)/$(UNITSUBDIR)
|
|
|
+endif
|
|
|
endif
|
|
|
|
|
|
# Where to install shared libraries
|
|
@@ -254,15 +306,33 @@ endif
|
|
|
# Where the doc files will be stored
|
|
|
ifndef DOCINSTALLDIR
|
|
|
ifdef inlinux
|
|
|
-DOCINSTALLDIR=$(PREFIXINSTALLDIR)/doc/fpc/$(FPC_VERSION)
|
|
|
+DOCINSTALLDIR=$(PREFIXINSTALLDIR)/doc/fpc-$(FPC_VERSION)
|
|
|
else
|
|
|
DOCINSTALLDIR=$(BASEINSTALLDIR)/doc
|
|
|
endif
|
|
|
endif
|
|
|
|
|
|
# Where the some extra (data)files will be stored
|
|
|
-ifndef EXTRAINSTALLDIR
|
|
|
-EXTRAINSTALLDIR=$(BASEINSTALLDIR)
|
|
|
+ifndef DATAINSTALLDIR
|
|
|
+DATAINSTALLDIR=$(BASEINSTALLDIR)
|
|
|
+endif
|
|
|
+
|
|
|
+#####################################################################
|
|
|
+# Redirection
|
|
|
+#####################################################################
|
|
|
+
|
|
|
+# Release ? Then force OPT and don't use extra opts via commandline
|
|
|
+ifndef REDIRFILE
|
|
|
+REDIRFILE=log
|
|
|
+endif
|
|
|
+
|
|
|
+ifdef REDIR
|
|
|
+ifndef inlinux
|
|
|
+override FPC=redir -eo $(FPC)
|
|
|
+endif
|
|
|
+# set the verbosity to max
|
|
|
+override FPCOPT+=-va
|
|
|
+override REDIR:= >> $(REDIRFILE)
|
|
|
endif
|
|
|
|
|
|
|
|
@@ -278,8 +348,8 @@ ifneq ($(OS_TARGET),$(OS_SOURCE))
|
|
|
override FPCOPT+=-T$(OS_TARGET)
|
|
|
endif
|
|
|
|
|
|
-ifdef RTLDIR
|
|
|
-override FPCOPT+=-Fu$(RTLDIR)
|
|
|
+ifdef NEEDUNITDIR
|
|
|
+override FPCOPT+=$(addprefix -Fu,$(NEEDUNITDIR))
|
|
|
endif
|
|
|
|
|
|
ifdef UNITSDIR
|
|
@@ -293,7 +363,17 @@ endif
|
|
|
|
|
|
# Debug
|
|
|
ifdef DEBUG
|
|
|
-override FPCOPT+=-g
|
|
|
+override FPCOPT+=-g -dDEBUG
|
|
|
+endif
|
|
|
+
|
|
|
+# Release mode (strip, optimize and don't load ppc386.cfg)
|
|
|
+ifdef RELEASE
|
|
|
+override FPCOPT+=-Xs -OG2p3 -n
|
|
|
+endif
|
|
|
+
|
|
|
+# Verbose settings (warning,note,info)
|
|
|
+ifdef VERBOSE
|
|
|
+override FPCOPT+=-vwni
|
|
|
endif
|
|
|
|
|
|
# Add commandline options
|
|
@@ -328,11 +408,10 @@ ifdef CFGFILE
|
|
|
override FPCOPT+=@$(CFGFILE)
|
|
|
endif
|
|
|
|
|
|
-# For win32 the options are passed using the environment variable FPCEXTCMD
|
|
|
+# For win32 the options are passed using the file fpcext.cmd
|
|
|
ifeq ($(OS_SOURCE),win32)
|
|
|
-override FPCEXTCMD:=$(FPCOPT)
|
|
|
-override FPCOPT:=!FPCEXTCMD
|
|
|
-export FPCEXTCMD
|
|
|
+override TMPVAR:=$(shell "$(ECHO) -e $(addprefix "\n",$(FPCOPT)) > fpcext.cmd")
|
|
|
+override FPCOPT:[email protected]
|
|
|
endif
|
|
|
|
|
|
# Compiler commandline
|
|
@@ -344,65 +423,62 @@ override COMPILER:=$(FPC) $(FPCOPT)
|
|
|
|
|
|
# To copy pograms
|
|
|
ifndef COPY
|
|
|
-export COPY:=cp -fp
|
|
|
+COPY:=cp -fp
|
|
|
endif
|
|
|
|
|
|
# Copy a whole tree
|
|
|
ifndef COPYTREE
|
|
|
-export COPYTREE:=cp -rfp
|
|
|
+COPYTREE:=cp -rfp
|
|
|
endif
|
|
|
|
|
|
# To move pograms
|
|
|
ifndef MOVE
|
|
|
-export MOVE:=mv -f
|
|
|
+MOVE:=mv -f
|
|
|
endif
|
|
|
|
|
|
# Check delete program
|
|
|
ifndef DEL
|
|
|
-export DEL:=rm -f
|
|
|
+DEL:=rm -f
|
|
|
endif
|
|
|
|
|
|
# Check deltree program
|
|
|
ifndef DELTREE
|
|
|
-export DELTREE:=rm -rf
|
|
|
+DELTREE:=rm -rf
|
|
|
endif
|
|
|
|
|
|
# To install files
|
|
|
ifndef INSTALL
|
|
|
ifdef inlinux
|
|
|
-export INSTALL:=install -m 644
|
|
|
+INSTALL:=install -m 644
|
|
|
else
|
|
|
-export INSTALL:=$(COPY)
|
|
|
+INSTALL:=$(COPY)
|
|
|
endif
|
|
|
endif
|
|
|
|
|
|
# To install programs
|
|
|
ifndef INSTALLEXE
|
|
|
ifdef inlinux
|
|
|
-export INSTALLEXE:=install -m 755
|
|
|
+INSTALLEXE:=install -m 755
|
|
|
else
|
|
|
-export INSTALLEXE:=$(COPY)
|
|
|
+INSTALLEXE:=$(COPY)
|
|
|
endif
|
|
|
endif
|
|
|
|
|
|
# To make a directory.
|
|
|
ifndef MKDIR
|
|
|
ifdef inlinux
|
|
|
-export MKDIR:=install -m 755 -d
|
|
|
+MKDIR:=install -m 755 -d
|
|
|
else
|
|
|
-export MKDIR:=ginstall -m 755 -d
|
|
|
+MKDIR:=ginstall -m 755 -d
|
|
|
endif
|
|
|
endif
|
|
|
|
|
|
+export COPY COPYTREE MOVE DEL DELTREE INSTALL INSTALLEXE MKDIR
|
|
|
+
|
|
|
#####################################################################
|
|
|
# Default Tools
|
|
|
#####################################################################
|
|
|
|
|
|
-# file used to check if a package is compiled
|
|
|
-ifndef FPCMAKED
|
|
|
-FPCMAKED=fpcmaked
|
|
|
-endif
|
|
|
-
|
|
|
# assembler, redefine it if cross compiling
|
|
|
ifndef AS
|
|
|
AS=as
|
|
@@ -438,25 +514,16 @@ else
|
|
|
LDCONFIG=
|
|
|
endif
|
|
|
|
|
|
-# echo
|
|
|
-ifndef ECHO
|
|
|
-ECHO:=$(strip $(wildcard $(addsuffix /echo$(EXEEXT),$(SEARCHPATH))))
|
|
|
-ifeq ($(ECHO),)
|
|
|
-export ECHO:=echo
|
|
|
-else
|
|
|
-export ECHO:=$(firstword $(ECHO))
|
|
|
-endif
|
|
|
-endif
|
|
|
-
|
|
|
# ppdep
|
|
|
ifndef PPDEP
|
|
|
PPDEP:=$(strip $(wildcard $(addsuffix /ppdep$(EXEEXT),$(SEARCHPATH))))
|
|
|
ifeq ($(PPDEP),)
|
|
|
PPDEP=
|
|
|
else
|
|
|
-export PPDEP:=$(firstword $(PPDEP))
|
|
|
+PPDEP:=$(firstword $(PPDEP))
|
|
|
endif
|
|
|
endif
|
|
|
+export PPDEP
|
|
|
|
|
|
# ppumove
|
|
|
ifndef PPUMOVE
|
|
@@ -464,9 +531,10 @@ PPUMOVE:=$(strip $(wildcard $(addsuffix /ppumove$(EXEEXT),$(SEARCHPATH))))
|
|
|
ifeq ($(PPUMOVE),)
|
|
|
PPUMOVE=
|
|
|
else
|
|
|
-export PPUMOVE:=$(firstword $(PPUMOVE))
|
|
|
+PPUMOVE:=$(firstword $(PPUMOVE))
|
|
|
endif
|
|
|
endif
|
|
|
+export PPUMOVE
|
|
|
|
|
|
# ppufiles
|
|
|
ifndef PPUFILES
|
|
@@ -474,9 +542,10 @@ PPUFILES:=$(strip $(wildcard $(addsuffix /ppufiles$(EXEEXT),$(SEARCHPATH))))
|
|
|
ifeq ($(PPUFILES),)
|
|
|
PPUFILES=
|
|
|
else
|
|
|
-export PPUFILES:=$(firstword $(PPUFILES))
|
|
|
+PPUFILES:=$(firstword $(PPUFILES))
|
|
|
endif
|
|
|
endif
|
|
|
+export PPUFILES
|
|
|
|
|
|
# Look if UPX is found for go32v2 and win32. We can't use $UPX becuase
|
|
|
# upx uses that one itself (PFV)
|
|
@@ -492,12 +561,13 @@ UPXPROG:=$(strip $(wildcard $(addsuffix /upx$(EXEEXT),$(SEARCHPATH))))
|
|
|
ifeq ($(UPXPROG),)
|
|
|
UPXPROG=
|
|
|
else
|
|
|
-export UPXPROG:=$(firstword $(UPXPROG))
|
|
|
+UPXPROG:=$(firstword $(UPXPROG))
|
|
|
endif
|
|
|
else
|
|
|
UPXPROG=
|
|
|
endif
|
|
|
endif
|
|
|
+export UPXPROG
|
|
|
|
|
|
# gdate/date
|
|
|
ifndef DATE
|
|
@@ -507,12 +577,13 @@ DATE:=$(strip $(wildcard $(addsuffix /gdate$(EXEEXT),$(SEACHPATH))))
|
|
|
ifeq ($(DATE),)
|
|
|
DATE=
|
|
|
else
|
|
|
-export DATE:=$(firstword $(DATE))
|
|
|
+DATE:=$(firstword $(DATE))
|
|
|
endif
|
|
|
else
|
|
|
-export DATE:=$(firstword $(DATE))
|
|
|
+DATE:=$(firstword $(DATE))
|
|
|
endif
|
|
|
endif
|
|
|
+export DATE
|
|
|
|
|
|
ifdef DATE
|
|
|
DATESTR:=$(shell $(DATE) +%Y%m%d)
|
|
@@ -526,9 +597,10 @@ ZIPPROG:=$(strip $(wildcard $(addsuffix /zip$(EXEEXT),$(SEARCHPATH))))
|
|
|
ifeq ($(ZIPPROG),)
|
|
|
ZIPPROG=
|
|
|
else
|
|
|
-export ZIPPROG:=$(firstword $(ZIPPROG)) -D9 -r
|
|
|
+ZIPPROG:=$(firstword $(ZIPPROG)) -D9 -r
|
|
|
endif
|
|
|
endif
|
|
|
+export ZIPPROG
|
|
|
|
|
|
ifndef ZIPEXT
|
|
|
ZIPEXT=.zip
|
|
@@ -547,7 +619,9 @@ ASMEXT=.s
|
|
|
SMARTEXT=.sl
|
|
|
STATICLIBEXT=.a
|
|
|
SHAREDLIBEXT=.so
|
|
|
+RSTEXT=.rst
|
|
|
PACKAGESUFFIX=
|
|
|
+FPCMADE=fpcmade
|
|
|
|
|
|
# Go32v1
|
|
|
ifeq ($(OS_TARGET),go32v1)
|
|
@@ -558,16 +632,19 @@ SMARTEXT=.sl1
|
|
|
STATICLIBEXT=.a1
|
|
|
SHAREDLIBEXT=.so1
|
|
|
PACKAGESUFFIX=v1
|
|
|
+FPCMADE=fpcmade.v1
|
|
|
endif
|
|
|
|
|
|
# Go32v2
|
|
|
ifeq ($(OS_TARGET),go32v2)
|
|
|
PACKAGESUFFIX=go32
|
|
|
+FPCMADE=fpcmade.dos
|
|
|
endif
|
|
|
|
|
|
# Linux
|
|
|
ifeq ($(OS_TARGET),linux)
|
|
|
PACKAGESUFFIX=linux
|
|
|
+FPCMADE=fpcmade.lnx
|
|
|
endif
|
|
|
|
|
|
# Win32
|
|
@@ -578,7 +655,8 @@ ASMEXT=.sw
|
|
|
SMARTEXT=.slw
|
|
|
STATICLIBEXT=.aw
|
|
|
SHAREDLIBEXT=.dll
|
|
|
-PACKAGESUFFIX=win32
|
|
|
+PACKAGESUFFIX=w32
|
|
|
+FPCMADE=fpcmade.w32
|
|
|
endif
|
|
|
|
|
|
# OS/2
|
|
@@ -590,6 +668,7 @@ SMARTEXT=.so
|
|
|
STATICLIBEXT=.ao2
|
|
|
SHAREDLIBEXT=.dll
|
|
|
PACKAGESUFFIX=os2
|
|
|
+FPCMADE=fpcmade.os2
|
|
|
endif
|
|
|
|
|
|
# library prefix
|
|
@@ -645,15 +724,15 @@ info: fpc_info
|
|
|
|
|
|
.PHONY: all debug smart shared showinstall install sourceinstall zipinstall zipinstalladd clean cleanall info
|
|
|
|
|
|
-#####################################################################
|
|
|
-# Package depends
|
|
|
-#####################################################################
|
|
|
|
|
|
-ifneq ($(wildcard $(RTLDIR)),)
|
|
|
-ifeq ($(wildcard $(RTLDIR)/$(FPCMAKED)),)
|
|
|
+PACKAGERTL=1
|
|
|
+ifdef PACKAGERTL
|
|
|
+ifneq ($(wildcard $(PACKAGEDIR_RTL)),)
|
|
|
+ifeq ($(wildcard $(PACKAGEDIR_RTL)/$(FPCMADE)),)
|
|
|
override COMPILEPACKAGES+=rtl
|
|
|
rtl_package:
|
|
|
- $(MAKE) -C $(RTLDIR) all
|
|
|
+ $(MAKE) -C $(PACKAGEDIR_RTL) all
|
|
|
+endif
|
|
|
endif
|
|
|
endif
|
|
|
|
|
@@ -678,14 +757,14 @@ fpc_exes: $(EXEFILES)
|
|
|
# General compile rules
|
|
|
#####################################################################
|
|
|
|
|
|
-.PHONY: fpc_all fpc_debug
|
|
|
+.PHONY: fpc_packages fpc_all fpc_debug
|
|
|
|
|
|
-$(FPCMAKED):
|
|
|
- @$(ECHO) Compiled > $(FPCMAKED)
|
|
|
+$(FPCMADE): $(ALLTARGET)
|
|
|
+ @$(ECHO) Compiled > $(FPCMADE)
|
|
|
|
|
|
-fpc_all: $(addsuffix _package,$(COMPILEPACKAGES)) \
|
|
|
- $(addsuffix _component,$(COMPILECOMPONENTS)) \
|
|
|
- $(ALLTARGET) $(FPCMAKED)
|
|
|
+fpc_packages: $(addsuffix _package,$(COMPILEPACKAGES))
|
|
|
+
|
|
|
+fpc_all: fpc_packages $(FPCMADE)
|
|
|
|
|
|
fpc_debug:
|
|
|
$(MAKE) all DEBUG=1
|
|
@@ -727,12 +806,12 @@ fpc_smart:
|
|
|
fpc_shared: all
|
|
|
ifdef inlinux
|
|
|
ifndef LIBNAME
|
|
|
- @$(ECHO) LIBNAME not set
|
|
|
+ @$(ECHO) "LIBNAME not set"
|
|
|
else
|
|
|
$(PPUMOVE) $(SHAREDLIBUNITOBJECTS) -o$(LIBNAME)
|
|
|
endif
|
|
|
else
|
|
|
- @$(ECHO) Shared Libraries not supported
|
|
|
+ @$(ECHO) "Shared Libraries not supported"
|
|
|
endif
|
|
|
|
|
|
#####################################################################
|
|
@@ -754,25 +833,25 @@ else
|
|
|
INSTALLPPULINKFILES:=$(shell $(PPUFILES) $(INSTALLPPUFILES))
|
|
|
endif
|
|
|
else
|
|
|
-INSTALLPPULINKFILES:=$(subst $(PPUEXT),$(OEXT),$(INSTALLPPUFILES))
|
|
|
+INSTALLPPULINKFILES:=$(wildcard $(subst $(PPUEXT),$(OEXT),$(INSTALLPPUFILES)))
|
|
|
endif
|
|
|
endif
|
|
|
|
|
|
fpc_showinstall: $(SHOWINSTALLTARGET)
|
|
|
ifdef INSTALLEXEFILES
|
|
|
- @$(ECHO) $(addprefix "\n"$(BININSTALLDIR)/,$(INSTALLEXEFILES))
|
|
|
+ @$(ECHO) -e $(addprefix "\n"$(BININSTALLDIR)/,$(INSTALLEXEFILES))
|
|
|
endif
|
|
|
ifdef INSTALLPPUFILES
|
|
|
- @$(ECHO) $(addprefix "\n"$(UNITINSTALLDIR)/,$(INSTALLPPUFILES))
|
|
|
+ @$(ECHO) -e $(addprefix "\n"$(UNITINSTALLDIR)/,$(INSTALLPPUFILES))
|
|
|
ifneq ($(INSTALLPPULINKFILES),)
|
|
|
- @$(ECHO) $(addprefix "\n"$(UNITINSTALLDIR)/,$(INSTALLPPULINKFILES))
|
|
|
+ @$(ECHO) -e $(addprefix "\n"$(UNITINSTALLDIR)/,$(INSTALLPPULINKFILES))
|
|
|
endif
|
|
|
ifneq ($(INSTALLPPULIBFILES),)
|
|
|
- @$(ECHO) $(addprefix "\n"$(LIBINSTALLDIR)/,$(INSTALLPPULIBFILES))
|
|
|
+ @$(ECHO) -e $(addprefix "\n"$(LIBINSTALLDIR)/,$(INSTALLPPULIBFILES))
|
|
|
endif
|
|
|
endif
|
|
|
ifdef EXTRAINSTALLFILES
|
|
|
- @$(ECHO) $(addprefix "\n"$(EXTRAINSTALLDIR)/,$(EXTRAINSTALLFILES))
|
|
|
+ @$(ECHO) -e $(addprefix "\n"$(DATAINSTALLDIR)/,$(EXTRAINSTALLFILES))
|
|
|
endif
|
|
|
|
|
|
fpc_install: $(INSTALLTARGET)
|
|
@@ -797,8 +876,8 @@ ifneq ($(INSTALLPPULIBFILES),)
|
|
|
endif
|
|
|
endif
|
|
|
ifdef EXTRAINSTALLFILES
|
|
|
- $(MKDIR) $(EXTRAINSTALLDIR)
|
|
|
- $(INSTALL) $(EXTRAINSTALLFILES) $(EXTRAINSTALLDIR)
|
|
|
+ $(MKDIR) $(DATAINSTALLDIR)
|
|
|
+ $(INSTALL) $(EXTRAINSTALLFILES) $(DATAINSTALLDIR)
|
|
|
endif
|
|
|
|
|
|
#####################################################################
|
|
@@ -831,6 +910,13 @@ ifndef DESTZIPDIR
|
|
|
DESTZIPDIR:=$(BASEDIR)
|
|
|
endif
|
|
|
|
|
|
+# Maybe create default zipname from packagename
|
|
|
+ifndef ZIPNAME
|
|
|
+ifdef PACKAGENAME
|
|
|
+ZIPNAME=$(PACKAGENAME)$(PACKAGESUFFIX)
|
|
|
+endif
|
|
|
+endif
|
|
|
+
|
|
|
# Add .zip/.tar.gz extension
|
|
|
ifdef ZIPNAME
|
|
|
ifndef inlinux
|
|
@@ -841,8 +927,8 @@ endif
|
|
|
# Note: This will not remove the zipfile first
|
|
|
fpc_zipinstalladd:
|
|
|
ifndef ZIPNAME
|
|
|
- @$(ECHO) Please specify ZIPNAME!
|
|
|
- @exit
|
|
|
+ @$(ECHO) "Please specify ZIPNAME!"
|
|
|
+ @exit 1
|
|
|
else
|
|
|
$(MAKE) $(ZIPTARGET) PREFIXINSTALLDIR=$(PACKDIR)
|
|
|
ifdef inlinux
|
|
@@ -858,8 +944,8 @@ endif
|
|
|
# First remove the zip and then install
|
|
|
fpc_zipinstall:
|
|
|
ifndef ZIPNAME
|
|
|
- @$(ECHO) Please specify ZIPNAME!
|
|
|
- @exit
|
|
|
+ @$(ECHO) "Please specify ZIPNAME!"
|
|
|
+ @exit 1
|
|
|
else
|
|
|
$(DEL) $(DESTZIPDIR)/$(ZIPNAME)
|
|
|
$(MAKE) $(ZIPTARGET) PREFIXINSTALLDIR=$(PACKDIR)
|
|
@@ -885,7 +971,7 @@ ifdef CLEANPPUFILES
|
|
|
ifdef PPUFILES
|
|
|
CLEANPPULINKFILES:=$(shell $(PPUFILES) $(CLEANPPUFILES))
|
|
|
else
|
|
|
-CLEANPPULINKFILES:=$(subst $(PPUEXT),$(OEXT),$(CLEANPPUFILES))
|
|
|
+CLEANPPULINKFILES:=$(wildcard $(subst $(PPUEXT),$(OEXT),$(CLEANPPUFILES)))
|
|
|
endif
|
|
|
endif
|
|
|
|
|
@@ -899,18 +985,21 @@ endif
|
|
|
ifneq ($(CLEANPPULINKFILES),)
|
|
|
-$(DEL) $(CLEANPPULINKFILES)
|
|
|
endif
|
|
|
+ifdef CLEANRSTFILES
|
|
|
+ -$(DEL) $(CLEANRSTFILES)
|
|
|
+endif
|
|
|
ifdef EXTRACLEANFILES
|
|
|
-$(DEL) $(EXTRACLEANFILES)
|
|
|
endif
|
|
|
- -$(DEL) $(FPCMAKED) $(PPAS) link.res $(REDIRFILE)
|
|
|
+ -$(DEL) $(FPCMADE) $(PPAS) link.res $(REDIRFILE)
|
|
|
|
|
|
fpc_cleanall: $(CLEANTARGET)
|
|
|
ifdef CLEANEXEFILES
|
|
|
-$(DEL) $(CLEANEXEFILES)
|
|
|
endif
|
|
|
- -$(DEL) *$(OEXT) *$(PPUEXT) *$(ASMEXT) *$(STATICLIBEXT) *$(SHAREDLIBEXT) *$(PPLEXT)
|
|
|
+ -$(DEL) *$(OEXT) *$(PPUEXT) *$(RSTEXT) *$(ASMEXT) *$(STATICLIBEXT) *$(SHAREDLIBEXT) *$(PPLEXT)
|
|
|
-$(DELTREE) *$(SMARTEXT)
|
|
|
- -$(DEL) $(FPCMAKED) $(PPAS) link.res $(REDIRFILE)
|
|
|
+ -$(DEL) $(FPCMADE) $(PPAS) link.res $(REDIRFILE)
|
|
|
|
|
|
#####################################################################
|
|
|
# Info rules
|
|
@@ -953,6 +1042,9 @@ fpc_infoinstall:
|
|
|
@$(ECHO)
|
|
|
ifdef DATE
|
|
|
@$(ECHO) DateStr.............. $(DATESTR)
|
|
|
+endif
|
|
|
+ifdef PACKAGENAME
|
|
|
+ @$(ECHO) PackageName.......... $(PACKAGENAME)
|
|
|
endif
|
|
|
@$(ECHO) PackageSuffix........ $(PACKAGESUFFIX)
|
|
|
@$(ECHO)
|
|
@@ -962,9 +1054,20 @@ endif
|
|
|
@$(ECHO) UnitInstallDir....... $(UNITINSTALLDIR)
|
|
|
@$(ECHO) SourceInstallDir..... $(SOURCEINSTALLDIR)
|
|
|
@$(ECHO) DocInstallDir........ $(DOCINSTALLDIR)
|
|
|
- @$(ECHO) ExtraInstallDir...... $(EXTRAINSTALLDIR)
|
|
|
+ @$(ECHO) DataInstallDir....... $(DATAINSTALLDIR)
|
|
|
+ @$(ECHO)
|
|
|
+ @$(ECHO) DestZipDir........... $(DESTZIPDIR)
|
|
|
+ @$(ECHO) ZipName.............. $(ZIPNAME)
|
|
|
@$(ECHO)
|
|
|
|
|
|
+#####################################################################
|
|
|
+# Local Makefile
|
|
|
+#####################################################################
|
|
|
+
|
|
|
+ifneq ($(wildcard fpcmake.loc),)
|
|
|
+include fpcmake.loc
|
|
|
+endif
|
|
|
+
|
|
|
#####################################################################
|
|
|
# Users rules
|
|
|
#####################################################################
|