|
@@ -1,12 +1,12 @@
|
|
|
#
|
|
#
|
|
|
-# Makefile generated by fpcmake v0.99.13 [2000/01/17]
|
|
|
|
|
|
|
+# Makefile generated by fpcmake v1.00 [2000/09/20]
|
|
|
#
|
|
#
|
|
|
|
|
|
|
|
defaultrule: all
|
|
defaultrule: all
|
|
|
|
|
|
|
|
#####################################################################
|
|
#####################################################################
|
|
|
# Autodetect OS (Linux or Dos or Windows NT)
|
|
# Autodetect OS (Linux or Dos or Windows NT)
|
|
|
-# define inlinux when running under linux
|
|
|
|
|
|
|
+# define inUnix when running under Unix (Linux,FreeBSD)
|
|
|
# define inWinNT when running under WinNT
|
|
# define inWinNT when running under WinNT
|
|
|
#####################################################################
|
|
#####################################################################
|
|
|
|
|
|
|
@@ -23,22 +23,18 @@ nopwd:
|
|
|
@echo Get ftp://ftp.freepascal.org/pub/fpc/dist/go32v2/utilgo32.zip
|
|
@echo Get ftp://ftp.freepascal.org/pub/fpc/dist/go32v2/utilgo32.zip
|
|
|
@exit
|
|
@exit
|
|
|
else
|
|
else
|
|
|
-inlinux=1
|
|
|
|
|
|
|
+inUnix=1
|
|
|
endif
|
|
endif
|
|
|
else
|
|
else
|
|
|
PWD:=$(firstword $(PWD))
|
|
PWD:=$(firstword $(PWD))
|
|
|
endif
|
|
endif
|
|
|
|
|
|
|
|
# Detect NT - NT sets OS to Windows_NT
|
|
# Detect NT - NT sets OS to Windows_NT
|
|
|
-ifndef inlinux
|
|
|
|
|
|
|
+# Detect OS/2 - OS/2 has OS2_SHELL defined
|
|
|
|
|
+ifndef inUnix
|
|
|
ifeq ($(OS),Windows_NT)
|
|
ifeq ($(OS),Windows_NT)
|
|
|
inWinNT=1
|
|
inWinNT=1
|
|
|
-endif
|
|
|
|
|
-endif
|
|
|
|
|
-
|
|
|
|
|
-# Detect OS/2 - OS/2 has OS2_SHELL defined
|
|
|
|
|
-ifndef inlinux
|
|
|
|
|
-ifndef inWinNT
|
|
|
|
|
|
|
+else
|
|
|
ifdef OS2_SHELL
|
|
ifdef OS2_SHELL
|
|
|
inOS2=1
|
|
inOS2=1
|
|
|
endif
|
|
endif
|
|
@@ -46,14 +42,14 @@ endif
|
|
|
endif
|
|
endif
|
|
|
|
|
|
|
|
# The extension of executables
|
|
# The extension of executables
|
|
|
-ifdef inlinux
|
|
|
|
|
-EXEEXT=
|
|
|
|
|
|
|
+ifdef inUnix
|
|
|
|
|
+SRCEXEEXT=
|
|
|
else
|
|
else
|
|
|
-EXEEXT=.exe
|
|
|
|
|
|
|
+SRCEXEEXT=.exe
|
|
|
endif
|
|
endif
|
|
|
|
|
|
|
|
# The path which is searched separated by spaces
|
|
# The path which is searched separated by spaces
|
|
|
-ifdef inlinux
|
|
|
|
|
|
|
+ifdef inUnix
|
|
|
SEARCHPATH=$(subst :, ,$(PATH))
|
|
SEARCHPATH=$(subst :, ,$(PATH))
|
|
|
else
|
|
else
|
|
|
SEARCHPATH=$(subst ;, ,$(PATH))
|
|
SEARCHPATH=$(subst ;, ,$(PATH))
|
|
@@ -83,13 +79,11 @@ ifndef FPC
|
|
|
ifdef PP
|
|
ifdef PP
|
|
|
FPC=$(PP)
|
|
FPC=$(PP)
|
|
|
else
|
|
else
|
|
|
-ifdef inOS2
|
|
|
|
|
-FPC=ppos2$(EXEEXT)
|
|
|
|
|
-else
|
|
|
|
|
-FPC=ppc386$(EXEEXT)
|
|
|
|
|
-endif
|
|
|
|
|
|
|
+FPC=ppc386
|
|
|
endif
|
|
endif
|
|
|
endif
|
|
endif
|
|
|
|
|
+override FPC:=$(subst $(SRCEXEEXT),,$(FPC))
|
|
|
|
|
+override FPC:=$(subst \,/,$(FPC))$(SRCEXEEXT)
|
|
|
|
|
|
|
|
# Target OS
|
|
# Target OS
|
|
|
ifndef OS_TARGET
|
|
ifndef OS_TARGET
|
|
@@ -152,8 +146,10 @@ endif
|
|
|
ifdef FPCDIR
|
|
ifdef FPCDIR
|
|
|
override FPCDIR:=$(subst \,/,$(FPCDIR))
|
|
override FPCDIR:=$(subst \,/,$(FPCDIR))
|
|
|
ifeq ($(wildcard $(FPCDIR)/rtl),)
|
|
ifeq ($(wildcard $(FPCDIR)/rtl),)
|
|
|
|
|
+ifeq ($(wildcard $(FPCDIR)/units),)
|
|
|
override FPCDIR=wrong
|
|
override FPCDIR=wrong
|
|
|
endif
|
|
endif
|
|
|
|
|
+endif
|
|
|
else
|
|
else
|
|
|
override FPCDIR=wrong
|
|
override FPCDIR=wrong
|
|
|
endif
|
|
endif
|
|
@@ -162,16 +158,32 @@ endif
|
|
|
ifeq ($(FPCDIR),wrong)
|
|
ifeq ($(FPCDIR),wrong)
|
|
|
override FPCDIR=.
|
|
override FPCDIR=.
|
|
|
ifeq ($(wildcard $(FPCDIR)/rtl),)
|
|
ifeq ($(wildcard $(FPCDIR)/rtl),)
|
|
|
|
|
+ifeq ($(wildcard $(FPCDIR)/units),)
|
|
|
override FPCDIR=wrong
|
|
override FPCDIR=wrong
|
|
|
endif
|
|
endif
|
|
|
endif
|
|
endif
|
|
|
|
|
+endif
|
|
|
|
|
|
|
|
# Detect FPCDIR
|
|
# Detect FPCDIR
|
|
|
ifeq ($(FPCDIR),wrong)
|
|
ifeq ($(FPCDIR),wrong)
|
|
|
-ifdef inlinux
|
|
|
|
|
|
|
+ifdef inUnix
|
|
|
|
|
+override FPCDIR=/usr/local/lib/fpc/$(FPC_VERSION)
|
|
|
|
|
+ifeq ($(wildcard $(FPCDIR)/units),)
|
|
|
override FPCDIR=/usr/lib/fpc/$(FPC_VERSION)
|
|
override FPCDIR=/usr/lib/fpc/$(FPC_VERSION)
|
|
|
|
|
+endif
|
|
|
else
|
|
else
|
|
|
-override FPCDIR:=$(subst /$(FPC)$(EXEEXT),,$(firstword $(strip $(wildcard $(addsuffix /$(FPC)$(EXEEXT),$(SEARCHPATH))))))
|
|
|
|
|
|
|
+override FPCDIR:=$(subst /$(FPC),,$(firstword $(strip $(wildcard $(addsuffix /$(FPC),$(SEARCHPATH))))))
|
|
|
|
|
+override FPCDIR:=$(FPCDIR)/..
|
|
|
|
|
+ifeq ($(wildcard $(FPCDIR)/rtl),)
|
|
|
|
|
+ifeq ($(wildcard $(FPCDIR)/units),)
|
|
|
|
|
+override FPCDIR:=$(FPCDIR)/..
|
|
|
|
|
+ifeq ($(wildcard $(FPCDIR)/rtl),)
|
|
|
|
|
+ifeq ($(wildcard $(FPCDIR)/units),)
|
|
|
|
|
+override FPCDIR=c:/pp
|
|
|
|
|
+endif
|
|
|
|
|
+endif
|
|
|
|
|
+endif
|
|
|
|
|
+endif
|
|
|
endif
|
|
endif
|
|
|
endif
|
|
endif
|
|
|
|
|
|
|
@@ -210,7 +222,8 @@ endif
|
|
|
# Libraries
|
|
# Libraries
|
|
|
|
|
|
|
|
LIBNAME=libfprtl.so
|
|
LIBNAME=libfprtl.so
|
|
|
-SHAREDLIBOBJECTUNITS=$(SYSTEMUNIT) objpas strings linux ports dos crt objects printer sysutils typinfo math cpu mmx getopts heaptrc errors sockets ipc dl dynlibs varutils
|
|
|
|
|
|
|
+LIBVERSION=1.0
|
|
|
|
|
+SHAREDLIBUNITOBJECTS=$(SYSTEMUNIT) objpas strings linux ports dos crt objects printer sysutils typinfo math cpu mmx getopts heaptrc errors sockets ipc dl dynlibs varutils
|
|
|
|
|
|
|
|
# Info
|
|
# Info
|
|
|
|
|
|
|
@@ -245,7 +258,7 @@ SYSDEPS=$(SYSINCDEPS) $(SYSCPUDEPS)
|
|
|
ifndef ECHO
|
|
ifndef ECHO
|
|
|
ECHO:=$(strip $(wildcard $(addsuffix /gecho$(EXEEXT),$(SEARCHPATH))))
|
|
ECHO:=$(strip $(wildcard $(addsuffix /gecho$(EXEEXT),$(SEARCHPATH))))
|
|
|
ifeq ($(ECHO),)
|
|
ifeq ($(ECHO),)
|
|
|
-ECHO:=$(strip $(wildcard $(addsuffix /echo$(EXEEXT),$(SEARCHPATH))))
|
|
|
|
|
|
|
+ECHO:=$(strip $(wildcard $(addsuffix /echo$(SRCEXEEXT),$(SEARCHPATH))))
|
|
|
ifeq ($(ECHO),)
|
|
ifeq ($(ECHO),)
|
|
|
ECHO:=echo
|
|
ECHO:=echo
|
|
|
ECHOE:=echo
|
|
ECHOE:=echo
|
|
@@ -286,7 +299,7 @@ endif
|
|
|
|
|
|
|
|
# To install files
|
|
# To install files
|
|
|
ifndef INSTALL
|
|
ifndef INSTALL
|
|
|
-ifdef inlinux
|
|
|
|
|
|
|
+ifdef inUnix
|
|
|
INSTALL:=install -m 644
|
|
INSTALL:=install -m 644
|
|
|
else
|
|
else
|
|
|
INSTALL:=$(COPY)
|
|
INSTALL:=$(COPY)
|
|
@@ -295,7 +308,7 @@ endif
|
|
|
|
|
|
|
|
# To install programs
|
|
# To install programs
|
|
|
ifndef INSTALLEXE
|
|
ifndef INSTALLEXE
|
|
|
-ifdef inlinux
|
|
|
|
|
|
|
+ifdef inUnix
|
|
|
INSTALLEXE:=install -m 755
|
|
INSTALLEXE:=install -m 755
|
|
|
else
|
|
else
|
|
|
INSTALLEXE:=$(COPY)
|
|
INSTALLEXE:=$(COPY)
|
|
@@ -304,7 +317,7 @@ endif
|
|
|
|
|
|
|
|
# To make a directory.
|
|
# To make a directory.
|
|
|
ifndef MKDIR
|
|
ifndef MKDIR
|
|
|
-ifdef inlinux
|
|
|
|
|
|
|
+ifdef inUnix
|
|
|
MKDIR:=install -m 755 -d
|
|
MKDIR:=install -m 755 -d
|
|
|
else
|
|
else
|
|
|
MKDIR:=ginstall -m 755 -d
|
|
MKDIR:=ginstall -m 755 -d
|
|
@@ -328,7 +341,7 @@ LD=ld
|
|
|
endif
|
|
endif
|
|
|
|
|
|
|
|
# ppas.bat / ppas.sh
|
|
# ppas.bat / ppas.sh
|
|
|
-ifdef inlinux
|
|
|
|
|
|
|
+ifdef inUnix
|
|
|
PPAS=ppas.sh
|
|
PPAS=ppas.sh
|
|
|
else
|
|
else
|
|
|
ifdef inOS2
|
|
ifdef inOS2
|
|
@@ -338,15 +351,8 @@ PPAS=ppas.bat
|
|
|
endif
|
|
endif
|
|
|
endif
|
|
endif
|
|
|
|
|
|
|
|
-# also call ppas if with command option -s
|
|
|
|
|
-ifeq (,$(findstring -s ,$(COMPILER)))
|
|
|
|
|
-EXECPPAS=
|
|
|
|
|
-else
|
|
|
|
|
-EXECPPAS:=@$(PPAS)
|
|
|
|
|
-endif
|
|
|
|
|
-
|
|
|
|
|
# ldconfig to rebuild .so cache
|
|
# ldconfig to rebuild .so cache
|
|
|
-ifdef inlinux
|
|
|
|
|
|
|
+ifdef inUnix
|
|
|
LDCONFIG=ldconfig
|
|
LDCONFIG=ldconfig
|
|
|
else
|
|
else
|
|
|
LDCONFIG=
|
|
LDCONFIG=
|
|
@@ -354,7 +360,7 @@ endif
|
|
|
|
|
|
|
|
# ppumove
|
|
# ppumove
|
|
|
ifndef PPUMOVE
|
|
ifndef PPUMOVE
|
|
|
-PPUMOVE:=$(strip $(wildcard $(addsuffix /ppumove$(EXEEXT),$(SEARCHPATH))))
|
|
|
|
|
|
|
+PPUMOVE:=$(strip $(wildcard $(addsuffix /ppumove$(SRCEXEEXT),$(SEARCHPATH))))
|
|
|
ifeq ($(PPUMOVE),)
|
|
ifeq ($(PPUMOVE),)
|
|
|
PPUMOVE=
|
|
PPUMOVE=
|
|
|
else
|
|
else
|
|
@@ -365,7 +371,7 @@ export PPUMOVE
|
|
|
|
|
|
|
|
# ppufiles
|
|
# ppufiles
|
|
|
ifndef PPUFILES
|
|
ifndef PPUFILES
|
|
|
-PPUFILES:=$(strip $(wildcard $(addsuffix /ppufiles$(EXEEXT),$(SEARCHPATH))))
|
|
|
|
|
|
|
+PPUFILES:=$(strip $(wildcard $(addsuffix /ppufiles$(SRCEXEEXT),$(SEARCHPATH))))
|
|
|
ifeq ($(PPUFILES),)
|
|
ifeq ($(PPUFILES),)
|
|
|
PPUFILES=
|
|
PPUFILES=
|
|
|
else
|
|
else
|
|
@@ -384,7 +390,7 @@ ifeq ($(OS_TARGET),win32)
|
|
|
UPXPROG:=1
|
|
UPXPROG:=1
|
|
|
endif
|
|
endif
|
|
|
ifdef UPXPROG
|
|
ifdef UPXPROG
|
|
|
-UPXPROG:=$(strip $(wildcard $(addsuffix /upx$(EXEEXT),$(SEARCHPATH))))
|
|
|
|
|
|
|
+UPXPROG:=$(strip $(wildcard $(addsuffix /upx$(SRCEXEEXT),$(SEARCHPATH))))
|
|
|
ifeq ($(UPXPROG),)
|
|
ifeq ($(UPXPROG),)
|
|
|
UPXPROG=
|
|
UPXPROG=
|
|
|
else
|
|
else
|
|
@@ -398,11 +404,11 @@ export UPXPROG
|
|
|
|
|
|
|
|
# ZipProg, you can't use Zip as the var name (PFV)
|
|
# ZipProg, you can't use Zip as the var name (PFV)
|
|
|
ifndef ZIPPROG
|
|
ifndef ZIPPROG
|
|
|
-ZIPPROG:=$(strip $(wildcard $(addsuffix /zip$(EXEEXT),$(SEARCHPATH))))
|
|
|
|
|
|
|
+ZIPPROG:=$(strip $(wildcard $(addsuffix /zip$(SRCEXEEXT),$(SEARCHPATH))))
|
|
|
ifeq ($(ZIPPROG),)
|
|
ifeq ($(ZIPPROG),)
|
|
|
ZIPPROG=
|
|
ZIPPROG=
|
|
|
else
|
|
else
|
|
|
-ZIPPROG:=$(firstword $(ZIPPROG)) -D9 -r
|
|
|
|
|
|
|
+ZIPPROG:=$(firstword $(ZIPPROG))
|
|
|
endif
|
|
endif
|
|
|
endif
|
|
endif
|
|
|
export ZIPPROG
|
|
export ZIPPROG
|
|
@@ -412,7 +418,7 @@ ZIPEXT=.zip
|
|
|
|
|
|
|
|
# Tar
|
|
# Tar
|
|
|
ifndef TARPROG
|
|
ifndef TARPROG
|
|
|
-TARPROG:=$(strip $(wildcard $(addsuffix /tar$(EXEEXT),$(SEARCHPATH))))
|
|
|
|
|
|
|
+TARPROG:=$(strip $(wildcard $(addsuffix /tar$(SRCEXEEXT),$(SEARCHPATH))))
|
|
|
ifeq ($(TARPROG),)
|
|
ifeq ($(TARPROG),)
|
|
|
TARPROG=
|
|
TARPROG=
|
|
|
else
|
|
else
|
|
@@ -435,6 +441,7 @@ endif
|
|
|
|
|
|
|
|
# Default needed extensions (Go32v2,Linux)
|
|
# Default needed extensions (Go32v2,Linux)
|
|
|
LOADEREXT=.as
|
|
LOADEREXT=.as
|
|
|
|
|
+EXEEXT=.exe
|
|
|
PPLEXT=.ppl
|
|
PPLEXT=.ppl
|
|
|
PPUEXT=.ppu
|
|
PPUEXT=.ppu
|
|
|
OEXT=.o
|
|
OEXT=.o
|
|
@@ -463,9 +470,18 @@ endif
|
|
|
|
|
|
|
|
# Linux
|
|
# Linux
|
|
|
ifeq ($(OS_TARGET),linux)
|
|
ifeq ($(OS_TARGET),linux)
|
|
|
|
|
+EXEEXT=
|
|
|
|
|
+HASSHAREDLIB=1
|
|
|
FPCMADE=fpcmade.lnx
|
|
FPCMADE=fpcmade.lnx
|
|
|
endif
|
|
endif
|
|
|
|
|
|
|
|
|
|
+# Linux
|
|
|
|
|
+ifeq ($(OS_TARGET),freebsd)
|
|
|
|
|
+EXEEXT=
|
|
|
|
|
+HASSHAREDLIB=1
|
|
|
|
|
+FPCMADE=fpcmade.freebsd
|
|
|
|
|
+endif
|
|
|
|
|
+
|
|
|
# Win32
|
|
# Win32
|
|
|
ifeq ($(OS_TARGET),win32)
|
|
ifeq ($(OS_TARGET),win32)
|
|
|
PPUEXT=.ppw
|
|
PPUEXT=.ppw
|
|
@@ -517,9 +533,17 @@ endif
|
|
|
# Default Directories
|
|
# Default Directories
|
|
|
#####################################################################
|
|
#####################################################################
|
|
|
|
|
|
|
|
|
|
+# Linux and freebsd use unix dirs with /usr/bin, /usr/lib
|
|
|
|
|
+ifeq ($(OS_TARGET),linux)
|
|
|
|
|
+UNIXINSTALLDIR=1
|
|
|
|
|
+endif
|
|
|
|
|
+ifeq ($(OS_TARGET),freebsd)
|
|
|
|
|
+UNIXINSTALLDIR=1
|
|
|
|
|
+endif
|
|
|
|
|
+
|
|
|
# set the prefix directory where to install everything
|
|
# set the prefix directory where to install everything
|
|
|
ifndef PREFIXINSTALLDIR
|
|
ifndef PREFIXINSTALLDIR
|
|
|
-ifdef inlinux
|
|
|
|
|
|
|
+ifdef UNIXINSTALLDIR
|
|
|
PREFIXINSTALLDIR=/usr
|
|
PREFIXINSTALLDIR=/usr
|
|
|
else
|
|
else
|
|
|
PREFIXINSTALLDIR=/pp
|
|
PREFIXINSTALLDIR=/pp
|
|
@@ -539,7 +563,7 @@ export DESTZIPDIR
|
|
|
|
|
|
|
|
# set the base directory where to install everything
|
|
# set the base directory where to install everything
|
|
|
ifndef BASEINSTALLDIR
|
|
ifndef BASEINSTALLDIR
|
|
|
-ifdef inlinux
|
|
|
|
|
|
|
+ifdef UNIXINSTALLDIR
|
|
|
BASEINSTALLDIR=$(PREFIXINSTALLDIR)/lib/fpc/$(FPC_VERSION)
|
|
BASEINSTALLDIR=$(PREFIXINSTALLDIR)/lib/fpc/$(FPC_VERSION)
|
|
|
else
|
|
else
|
|
|
BASEINSTALLDIR=$(PREFIXINSTALLDIR)
|
|
BASEINSTALLDIR=$(PREFIXINSTALLDIR)
|
|
@@ -548,7 +572,7 @@ endif
|
|
|
|
|
|
|
|
# set the directory where to install the binaries
|
|
# set the directory where to install the binaries
|
|
|
ifndef BININSTALLDIR
|
|
ifndef BININSTALLDIR
|
|
|
-ifdef inlinux
|
|
|
|
|
|
|
+ifdef UNIXINSTALLDIR
|
|
|
BININSTALLDIR=$(PREFIXINSTALLDIR)/bin
|
|
BININSTALLDIR=$(PREFIXINSTALLDIR)/bin
|
|
|
else
|
|
else
|
|
|
BININSTALLDIR=$(BASEINSTALLDIR)/bin/$(OS_TARGET)
|
|
BININSTALLDIR=$(BASEINSTALLDIR)/bin/$(OS_TARGET)
|
|
@@ -565,7 +589,7 @@ endif
|
|
|
|
|
|
|
|
# Where to install shared libraries
|
|
# Where to install shared libraries
|
|
|
ifndef LIBINSTALLDIR
|
|
ifndef LIBINSTALLDIR
|
|
|
-ifdef inlinux
|
|
|
|
|
|
|
+ifdef UNIXINSTALLDIR
|
|
|
LIBINSTALLDIR=$(PREFIXINSTALLDIR)/lib
|
|
LIBINSTALLDIR=$(PREFIXINSTALLDIR)/lib
|
|
|
else
|
|
else
|
|
|
LIBINSTALLDIR=$(UNITINSTALLDIR)
|
|
LIBINSTALLDIR=$(UNITINSTALLDIR)
|
|
@@ -574,7 +598,7 @@ endif
|
|
|
|
|
|
|
|
# Where the source files will be stored
|
|
# Where the source files will be stored
|
|
|
ifndef SOURCEINSTALLDIR
|
|
ifndef SOURCEINSTALLDIR
|
|
|
-ifdef inlinux
|
|
|
|
|
|
|
+ifdef UNIXINSTALLDIR
|
|
|
SOURCEINSTALLDIR=$(PREFIXINSTALLDIR)/src/fpc-$(FPC_VERSION)
|
|
SOURCEINSTALLDIR=$(PREFIXINSTALLDIR)/src/fpc-$(FPC_VERSION)
|
|
|
else
|
|
else
|
|
|
SOURCEINSTALLDIR=$(BASEINSTALLDIR)/source
|
|
SOURCEINSTALLDIR=$(BASEINSTALLDIR)/source
|
|
@@ -586,13 +610,26 @@ endif
|
|
|
|
|
|
|
|
# Where the doc files will be stored
|
|
# Where the doc files will be stored
|
|
|
ifndef DOCINSTALLDIR
|
|
ifndef DOCINSTALLDIR
|
|
|
-ifdef inlinux
|
|
|
|
|
|
|
+ifdef UNIXINSTALLDIR
|
|
|
DOCINSTALLDIR=$(PREFIXINSTALLDIR)/doc/fpc-$(FPC_VERSION)
|
|
DOCINSTALLDIR=$(PREFIXINSTALLDIR)/doc/fpc-$(FPC_VERSION)
|
|
|
else
|
|
else
|
|
|
DOCINSTALLDIR=$(BASEINSTALLDIR)/doc
|
|
DOCINSTALLDIR=$(BASEINSTALLDIR)/doc
|
|
|
endif
|
|
endif
|
|
|
endif
|
|
endif
|
|
|
|
|
|
|
|
|
|
+# Where to install the examples, under linux we use the doc dir
|
|
|
|
|
+# because the copytree command will create a subdir itself
|
|
|
|
|
+ifndef EXAMPLEINSTALLDIR
|
|
|
|
|
+ifdef UNIXINSTALLDIR
|
|
|
|
|
+EXAMPLEINSTALLDIR=$(DOCINSTALLDIR)/examples
|
|
|
|
|
+else
|
|
|
|
|
+EXAMPLEINSTALLDIR=$(BASEINSTALLDIR)/examples
|
|
|
|
|
+endif
|
|
|
|
|
+ifdef EXAMPLESUBDIR
|
|
|
|
|
+EXAMPLEINSTALLDIR:=$(EXAMPLEINSTALLDIR)/$(EXAMPLESUBDIR)
|
|
|
|
|
+endif
|
|
|
|
|
+endif
|
|
|
|
|
+
|
|
|
# Where the some extra (data)files will be stored
|
|
# Where the some extra (data)files will be stored
|
|
|
ifndef DATAINSTALLDIR
|
|
ifndef DATAINSTALLDIR
|
|
|
DATAINSTALLDIR=$(BASEINSTALLDIR)
|
|
DATAINSTALLDIR=$(BASEINSTALLDIR)
|
|
@@ -602,13 +639,12 @@ endif
|
|
|
# Redirection
|
|
# Redirection
|
|
|
#####################################################################
|
|
#####################################################################
|
|
|
|
|
|
|
|
-# Release ? Then force OPT and don't use extra opts via commandline
|
|
|
|
|
ifndef REDIRFILE
|
|
ifndef REDIRFILE
|
|
|
REDIRFILE=log
|
|
REDIRFILE=log
|
|
|
endif
|
|
endif
|
|
|
|
|
|
|
|
ifdef REDIR
|
|
ifdef REDIR
|
|
|
-ifndef inlinux
|
|
|
|
|
|
|
+ifndef inUnix
|
|
|
override FPC=redir -eo $(FPC)
|
|
override FPC=redir -eo $(FPC)
|
|
|
endif
|
|
endif
|
|
|
# set the verbosity to max
|
|
# set the verbosity to max
|
|
@@ -629,22 +665,27 @@ ifneq ($(OS_TARGET),$(OS_SOURCE))
|
|
|
override FPCOPT+=-T$(OS_TARGET)
|
|
override FPCOPT+=-T$(OS_TARGET)
|
|
|
endif
|
|
endif
|
|
|
|
|
|
|
|
-ifdef UNITSDIR
|
|
|
|
|
-override FPCOPT+=-Fu$(UNITSDIR)
|
|
|
|
|
|
|
+# User dirs should be first, so they are looked at first
|
|
|
|
|
+ifdef UNITDIR
|
|
|
|
|
+override FPCOPT+=$(addprefix -Fu,$(UNITDIR))
|
|
|
endif
|
|
endif
|
|
|
-
|
|
|
|
|
-ifdef NEEDINCDIR
|
|
|
|
|
-override FPCOPT+=$(addprefix -Fi,$(NEEDINCDIR))
|
|
|
|
|
|
|
+ifdef LIBDIR
|
|
|
|
|
+override FPCOPT+=$(addprefix -Fl,$(LIBDIR))
|
|
|
endif
|
|
endif
|
|
|
-
|
|
|
|
|
-
|
|
|
|
|
-# Target dirs
|
|
|
|
|
-ifdef TARGETDIR
|
|
|
|
|
-override FPCOPT+=-FE$(TARGETDIR)
|
|
|
|
|
|
|
+ifdef OBJDIR
|
|
|
|
|
+override FPCOPT+=$(addprefix -Fo,$(OBJDIR))
|
|
|
|
|
+endif
|
|
|
|
|
+ifdef INCDIR
|
|
|
|
|
+override FPCOPT+=$(addprefix -Fi,$(INCDIR))
|
|
|
endif
|
|
endif
|
|
|
|
|
|
|
|
# Smartlinking
|
|
# Smartlinking
|
|
|
-ifdef SMARTLINK
|
|
|
|
|
|
|
+ifdef LINKSMART
|
|
|
|
|
+override FPCOPT+=-XX
|
|
|
|
|
+endif
|
|
|
|
|
+
|
|
|
|
|
+# Smartlinking creation
|
|
|
|
|
+ifdef CREATESMART
|
|
|
override FPCOPT+=-CX
|
|
override FPCOPT+=-CX
|
|
|
endif
|
|
endif
|
|
|
|
|
|
|
@@ -654,30 +695,65 @@ override FPCOPT+=-g -dDEBUG
|
|
|
endif
|
|
endif
|
|
|
|
|
|
|
|
# Release mode (strip, optimize and don't load ppc386.cfg)
|
|
# Release mode (strip, optimize and don't load ppc386.cfg)
|
|
|
|
|
+# 0.99.12b has a bug in the optimizer so don't use it by default
|
|
|
ifdef RELEASE
|
|
ifdef RELEASE
|
|
|
|
|
+ifeq ($(FPC_VERSION),0.99.12)
|
|
|
|
|
+override FPCOPT+=-Xs -OGp3 -n
|
|
|
|
|
+else
|
|
|
override FPCOPT+=-Xs -OG2p3 -n
|
|
override FPCOPT+=-Xs -OG2p3 -n
|
|
|
endif
|
|
endif
|
|
|
|
|
+endif
|
|
|
|
|
+
|
|
|
|
|
+# Strip
|
|
|
|
|
+ifdef STRIP
|
|
|
|
|
+override FPCOPT+=-Xs
|
|
|
|
|
+endif
|
|
|
|
|
+
|
|
|
|
|
+# Optimizer
|
|
|
|
|
+ifdef OPTIMIZE
|
|
|
|
|
+override FPCOPT+=-OG2p3
|
|
|
|
|
+endif
|
|
|
|
|
|
|
|
# Verbose settings (warning,note,info)
|
|
# Verbose settings (warning,note,info)
|
|
|
ifdef VERBOSE
|
|
ifdef VERBOSE
|
|
|
override FPCOPT+=-vwni
|
|
override FPCOPT+=-vwni
|
|
|
endif
|
|
endif
|
|
|
|
|
|
|
|
-# Add commandline options
|
|
|
|
|
-ifdef OPT
|
|
|
|
|
-override FPCOPT+=$(OPT)
|
|
|
|
|
|
|
+ifdef UNITSDIR
|
|
|
|
|
+override FPCOPT+=-Fu$(UNITSDIR)
|
|
|
endif
|
|
endif
|
|
|
-ifdef UNITDIR
|
|
|
|
|
-override FPCOPT+=$(addprefix -Fu,$(UNITDIR))
|
|
|
|
|
|
|
+
|
|
|
|
|
+ifdef NEEDINCDIR
|
|
|
|
|
+override FPCOPT+=$(addprefix -Fi,$(NEEDINCDIR))
|
|
|
endif
|
|
endif
|
|
|
-ifdef LIBDIR
|
|
|
|
|
-override FPCOPT+=$(addprefix -Fl,$(LIBDIR))
|
|
|
|
|
|
|
+
|
|
|
|
|
+
|
|
|
|
|
+# Target dirs and the prefix to use for clean/install
|
|
|
|
|
+ifdef TARGETDIR
|
|
|
|
|
+override FPCOPT+=-FE$(TARGETDIR)
|
|
|
|
|
+ifeq ($(TARGETDIR),.)
|
|
|
|
|
+override TARGETDIRPREFIX=
|
|
|
|
|
+else
|
|
|
|
|
+override TARGETDIRPREFIX=$(TARGETDIR)/
|
|
|
endif
|
|
endif
|
|
|
-ifdef OBJDIR
|
|
|
|
|
-override FPCOPT+=$(addprefix -Fo,$(OBJDIR))
|
|
|
|
|
endif
|
|
endif
|
|
|
-ifdef INCDIR
|
|
|
|
|
-override FPCOPT+=$(addprefix -Fi,$(INCDIR))
|
|
|
|
|
|
|
+ifdef UNITTARGETDIR
|
|
|
|
|
+override FPCOPT+=-FU$(UNITTARGETDIR)
|
|
|
|
|
+ifeq ($(UNITTARGETDIR),.)
|
|
|
|
|
+override UNITTARGETDIRPREFIX=
|
|
|
|
|
+else
|
|
|
|
|
+override UNITTARGETDIRPREFIX=$(TARGETDIR)/
|
|
|
|
|
+endif
|
|
|
|
|
+else
|
|
|
|
|
+ifdef TARGETDIR
|
|
|
|
|
+override UNITTARGETDIR=$(TARGETDIR)
|
|
|
|
|
+override UNITTARGETDIRPREFIX=$(TARGETDIRPREFIX)
|
|
|
|
|
+endif
|
|
|
|
|
+endif
|
|
|
|
|
+
|
|
|
|
|
+# Add commandline options last so they can override
|
|
|
|
|
+ifdef OPT
|
|
|
|
|
+override FPCOPT+=$(OPT)
|
|
|
endif
|
|
endif
|
|
|
|
|
|
|
|
# Add defines from FPCOPTDEF to FPCOPT
|
|
# Add defines from FPCOPTDEF to FPCOPT
|
|
@@ -699,11 +775,22 @@ endif
|
|
|
ifeq ($(OS_SOURCE),win32)
|
|
ifeq ($(OS_SOURCE),win32)
|
|
|
override FPCEXTCMD:=$(FPCOPT)
|
|
override FPCEXTCMD:=$(FPCOPT)
|
|
|
override FPCOPT:=!FPCEXTCMD
|
|
override FPCOPT:=!FPCEXTCMD
|
|
|
|
|
+export FPCEXTCMD
|
|
|
endif
|
|
endif
|
|
|
|
|
|
|
|
# Compiler commandline
|
|
# Compiler commandline
|
|
|
override COMPILER:=$(FPC) $(FPCOPT)
|
|
override COMPILER:=$(FPC) $(FPCOPT)
|
|
|
|
|
|
|
|
|
|
+# also call ppas if with command option -s
|
|
|
|
|
+# but only if the OS_SOURCE and OS_TARGE are equal
|
|
|
|
|
+ifeq (,$(findstring -s ,$(COMPILER)))
|
|
|
|
|
+EXECPPAS=
|
|
|
|
|
+else
|
|
|
|
|
+ifeq ($(OS_SOURCE),$(OS_TARGET))
|
|
|
|
|
+EXECPPAS:=@$(PPAS)
|
|
|
|
|
+endif
|
|
|
|
|
+endif
|
|
|
|
|
+
|
|
|
#####################################################################
|
|
#####################################################################
|
|
|
# Standard rules
|
|
# Standard rules
|
|
|
#####################################################################
|
|
#####################################################################
|
|
@@ -722,17 +809,23 @@ install: fpc_install
|
|
|
|
|
|
|
|
sourceinstall: fpc_sourceinstall
|
|
sourceinstall: fpc_sourceinstall
|
|
|
|
|
|
|
|
|
|
+exampleinstall: fpc_exampleinstall
|
|
|
|
|
+
|
|
|
zipinstall: fpc_zipinstall
|
|
zipinstall: fpc_zipinstall
|
|
|
|
|
|
|
|
zipsourceinstall: fpc_zipsourceinstall
|
|
zipsourceinstall: fpc_zipsourceinstall
|
|
|
|
|
|
|
|
|
|
+zipexampleinstall: fpc_zipexampleinstall
|
|
|
|
|
+
|
|
|
clean: fpc_clean
|
|
clean: fpc_clean
|
|
|
|
|
|
|
|
|
|
+distclean: fpc_distclean
|
|
|
|
|
+
|
|
|
cleanall: fpc_cleanall
|
|
cleanall: fpc_cleanall
|
|
|
|
|
|
|
|
info: fpc_info
|
|
info: fpc_info
|
|
|
|
|
|
|
|
-.PHONY: all debug smart shared showinstall install sourceinstall zipinstall zipsourceinstall clean cleanall info
|
|
|
|
|
|
|
+.PHONY: all debug smart shared showinstall install sourceinstall exampleinstall zipinstall zipsourceinstall zipexampleinstall clean distclean cleanall info
|
|
|
|
|
|
|
|
#####################################################################
|
|
#####################################################################
|
|
|
# Loaders
|
|
# Loaders
|
|
@@ -780,9 +873,11 @@ fpc_units: $(UNITPPUFILES)
|
|
|
# Resource strings
|
|
# Resource strings
|
|
|
#####################################################################
|
|
#####################################################################
|
|
|
|
|
|
|
|
|
|
+ifdef RSTOBJECTS
|
|
|
override RSTFILES=$(addsuffix $(RSTEXT),$(RSTOBJECTS))
|
|
override RSTFILES=$(addsuffix $(RSTEXT),$(RSTOBJECTS))
|
|
|
|
|
|
|
|
override CLEANRSTFILES+=$(RSTFILES)
|
|
override CLEANRSTFILES+=$(RSTFILES)
|
|
|
|
|
+endif
|
|
|
|
|
|
|
|
#####################################################################
|
|
#####################################################################
|
|
|
# General compile rules
|
|
# General compile rules
|
|
@@ -800,25 +895,30 @@ fpc_all: fpc_packages $(FPCMADE)
|
|
|
fpc_debug:
|
|
fpc_debug:
|
|
|
$(MAKE) all DEBUG=1
|
|
$(MAKE) all DEBUG=1
|
|
|
|
|
|
|
|
|
|
+# Search paths for .ppu if targetdir is set
|
|
|
|
|
+ifdef UNITTARGETDIR
|
|
|
|
|
+vpath %$(PPUEXT) $(UNITTARGETDIR)
|
|
|
|
|
+endif
|
|
|
|
|
+
|
|
|
# General compile rules, available for both possible PASEXT
|
|
# General compile rules, available for both possible PASEXT
|
|
|
|
|
|
|
|
.SUFFIXES: $(EXEEXT) $(PPUEXT) $(OEXT) .pas .pp
|
|
.SUFFIXES: $(EXEEXT) $(PPUEXT) $(OEXT) .pas .pp
|
|
|
|
|
|
|
|
%$(PPUEXT): %.pp
|
|
%$(PPUEXT): %.pp
|
|
|
$(COMPILER) $< $(REDIR)
|
|
$(COMPILER) $< $(REDIR)
|
|
|
- $(EXECPASS)
|
|
|
|
|
|
|
+ $(EXECPPAS)
|
|
|
|
|
|
|
|
%$(PPUEXT): %.pas
|
|
%$(PPUEXT): %.pas
|
|
|
$(COMPILER) $< $(REDIR)
|
|
$(COMPILER) $< $(REDIR)
|
|
|
- $(EXECPASS)
|
|
|
|
|
|
|
+ $(EXECPPAS)
|
|
|
|
|
|
|
|
%$(EXEEXT): %.pp
|
|
%$(EXEEXT): %.pp
|
|
|
$(COMPILER) $< $(REDIR)
|
|
$(COMPILER) $< $(REDIR)
|
|
|
- $(EXECPASS)
|
|
|
|
|
|
|
+ $(EXECPPAS)
|
|
|
|
|
|
|
|
%$(EXEEXT): %.pas
|
|
%$(EXEEXT): %.pas
|
|
|
$(COMPILER) $< $(REDIR)
|
|
$(COMPILER) $< $(REDIR)
|
|
|
- $(EXECPASS)
|
|
|
|
|
|
|
+ $(EXECPPAS)
|
|
|
|
|
|
|
|
#####################################################################
|
|
#####################################################################
|
|
|
# Library
|
|
# Library
|
|
@@ -826,20 +926,26 @@ fpc_debug:
|
|
|
|
|
|
|
|
.PHONY: fpc_smart fpc_shared
|
|
.PHONY: fpc_smart fpc_shared
|
|
|
|
|
|
|
|
|
|
+ifdef LIBVERSION
|
|
|
|
|
+LIBFULLNAME=$(LIBNAME).$(LIBVERSION)
|
|
|
|
|
+else
|
|
|
|
|
+LIBFULLNAME=$(LIBNAME)
|
|
|
|
|
+endif
|
|
|
|
|
+
|
|
|
# Default sharedlib units are all unit objects
|
|
# Default sharedlib units are all unit objects
|
|
|
ifndef SHAREDLIBUNITOBJECTS
|
|
ifndef SHAREDLIBUNITOBJECTS
|
|
|
SHAREDLIBUNITOBJECTS:=$(UNITOBJECTS)
|
|
SHAREDLIBUNITOBJECTS:=$(UNITOBJECTS)
|
|
|
endif
|
|
endif
|
|
|
|
|
|
|
|
fpc_smart:
|
|
fpc_smart:
|
|
|
- $(MAKE) all SMARTLINK=1
|
|
|
|
|
|
|
+ $(MAKE) all LINKSMART=1 CREATESMART=1
|
|
|
|
|
|
|
|
fpc_shared: all
|
|
fpc_shared: all
|
|
|
-ifdef inlinux
|
|
|
|
|
|
|
+ifdef HASSHAREDLIB
|
|
|
ifndef LIBNAME
|
|
ifndef LIBNAME
|
|
|
@$(ECHO) "LIBNAME not set"
|
|
@$(ECHO) "LIBNAME not set"
|
|
|
else
|
|
else
|
|
|
- $(PPUMOVE) $(SHAREDLIBUNITOBJECTS) -o$(LIBNAME)
|
|
|
|
|
|
|
+ $(PPUMOVE) $(SHAREDLIBUNITOBJECTS) -o$(LIBFULLNAME)
|
|
|
endif
|
|
endif
|
|
|
else
|
|
else
|
|
|
@$(ECHO) "Shared Libraries not supported"
|
|
@$(ECHO) "Shared Libraries not supported"
|
|
@@ -856,16 +962,17 @@ override INSTALLPPUFILES+=$(addsuffix $(PPUEXT),$(EXTRAINSTALLUNITS))
|
|
|
endif
|
|
endif
|
|
|
|
|
|
|
|
ifdef INSTALLPPUFILES
|
|
ifdef INSTALLPPUFILES
|
|
|
|
|
+override INSTALLPPUFILES:=$(addprefix $(TARGETDIRPREFIX),$(INSTALLPPUFILES))
|
|
|
ifdef PPUFILES
|
|
ifdef PPUFILES
|
|
|
-ifdef inlinux
|
|
|
|
|
INSTALLPPULINKFILES:=$(shell $(PPUFILES) -S -O $(INSTALLPPUFILES))
|
|
INSTALLPPULINKFILES:=$(shell $(PPUFILES) -S -O $(INSTALLPPUFILES))
|
|
|
-INSTALLPPULIBFILES:=$(shell $(PPUFILES) -L $(INSTALLPPUFILES))
|
|
|
|
|
else
|
|
else
|
|
|
-INSTALLPPULINKFILES:=$(shell $(PPUFILES) $(INSTALLPPUFILES))
|
|
|
|
|
|
|
+INSTALLPPULINKFILES:=$(wildcard $(subst $(PPUEXT),$(OEXT),$(INSTALLPPUFILES)) $(addprefix $(LIBPREFIX),$(subst $(PPUEXT),$(STATICLIBEXT),$(INSTALLPPUFILES))))
|
|
|
endif
|
|
endif
|
|
|
-else
|
|
|
|
|
-INSTALLPPULINKFILES:=$(wildcard $(subst $(PPUEXT),$(OEXT),$(INSTALLPPUFILES)))
|
|
|
|
|
|
|
+override INSTALLPPULINKFILES:=$(addprefix $(TARGETDIRPREFIX),$(INSTALLPPULINKFILES))
|
|
|
endif
|
|
endif
|
|
|
|
|
+
|
|
|
|
|
+ifdef INSTALLEXEFILES
|
|
|
|
|
+override INSTALLEXEFILES:=$(addprefix $(TARGETDIRPREFIX),$(INSTALLEXEFILES))
|
|
|
endif
|
|
endif
|
|
|
|
|
|
|
|
fpc_showinstall: $(SHOWINSTALLTARGET)
|
|
fpc_showinstall: $(SHOWINSTALLTARGET)
|
|
@@ -877,8 +984,11 @@ ifdef INSTALLPPUFILES
|
|
|
ifneq ($(INSTALLPPULINKFILES),)
|
|
ifneq ($(INSTALLPPULINKFILES),)
|
|
|
@$(ECHO) -e $(addprefix "\n"$(UNITINSTALLDIR)/,$(INSTALLPPULINKFILES))
|
|
@$(ECHO) -e $(addprefix "\n"$(UNITINSTALLDIR)/,$(INSTALLPPULINKFILES))
|
|
|
endif
|
|
endif
|
|
|
-ifneq ($(INSTALLPPULIBFILES),)
|
|
|
|
|
- @$(ECHO) -e $(addprefix "\n"$(LIBINSTALLDIR)/,$(INSTALLPPULIBFILES))
|
|
|
|
|
|
|
+ifneq ($(wildcard $(LIBFULLNAME)),)
|
|
|
|
|
+ @$(ECHO) $(LIBINSTALLDIR)/$(LIBFULLNAME)
|
|
|
|
|
+ifdef HASSHAREDLIB
|
|
|
|
|
+ @$(ECHO) $(LIBINSTALLDIR)/$(LIBNAME)
|
|
|
|
|
+endif
|
|
|
endif
|
|
endif
|
|
|
endif
|
|
endif
|
|
|
ifdef EXTRAINSTALLFILES
|
|
ifdef EXTRAINSTALLFILES
|
|
@@ -901,9 +1011,12 @@ ifdef INSTALLPPUFILES
|
|
|
ifneq ($(INSTALLPPULINKFILES),)
|
|
ifneq ($(INSTALLPPULINKFILES),)
|
|
|
$(INSTALL) $(INSTALLPPULINKFILES) $(UNITINSTALLDIR)
|
|
$(INSTALL) $(INSTALLPPULINKFILES) $(UNITINSTALLDIR)
|
|
|
endif
|
|
endif
|
|
|
-ifneq ($(INSTALLPPULIBFILES),)
|
|
|
|
|
|
|
+ifneq ($(wildcard $(LIBFULLNAME)),)
|
|
|
$(MKDIR) $(LIBINSTALLDIR)
|
|
$(MKDIR) $(LIBINSTALLDIR)
|
|
|
- $(INSTALL) $(INSTALLPPULIBFILES) $(LIBINSTALLDIR)
|
|
|
|
|
|
|
+ $(INSTALL) $(LIBFULLNAME) $(LIBINSTALLDIR)
|
|
|
|
|
+ifdef inUnix
|
|
|
|
|
+ ln -sf $(LIBFULLNAME) $(LIBINSTALLDIR)/$(LIBNAME)
|
|
|
|
|
+endif
|
|
|
endif
|
|
endif
|
|
|
endif
|
|
endif
|
|
|
ifdef EXTRAINSTALLFILES
|
|
ifdef EXTRAINSTALLFILES
|
|
@@ -925,6 +1038,24 @@ fpc_sourceinstall: clean
|
|
|
$(MKDIR) $(SOURCEINSTALLDIR)
|
|
$(MKDIR) $(SOURCEINSTALLDIR)
|
|
|
$(COPYTREE) $(SOURCETOPDIR) $(SOURCEINSTALLDIR)
|
|
$(COPYTREE) $(SOURCETOPDIR) $(SOURCEINSTALLDIR)
|
|
|
|
|
|
|
|
|
|
+#####################################################################
|
|
|
|
|
+# exampleinstall rules
|
|
|
|
|
+#####################################################################
|
|
|
|
|
+
|
|
|
|
|
+.PHONY: fpc_exampleinstall
|
|
|
|
|
+
|
|
|
|
|
+fpc_exampleinstall: $(addsuffix _clean,$(EXAMPLEDIROBJECTS))
|
|
|
|
|
+ifdef EXAMPLESOURCEFILES
|
|
|
|
|
+ $(MKDIR) $(EXAMPLEINSTALLDIR)
|
|
|
|
|
+ $(COPY) $(EXAMPLESOURCEFILES) $(EXAMPLEINSTALLDIR)
|
|
|
|
|
+endif
|
|
|
|
|
+ifdef EXAMPLEDIROBJECTS
|
|
|
|
|
+ifndef EXAMPLESOURCEFILES
|
|
|
|
|
+ $(MKDIR) $(EXAMPLEINSTALLDIR)
|
|
|
|
|
+endif
|
|
|
|
|
+ $(COPYTREE) $(addsuffix /*,$(EXAMPLEDIROBJECTS)) $(EXAMPLEINSTALLDIR)
|
|
|
|
|
+endif
|
|
|
|
|
+
|
|
|
#####################################################################
|
|
#####################################################################
|
|
|
# Zip
|
|
# Zip
|
|
|
#####################################################################
|
|
#####################################################################
|
|
@@ -944,7 +1075,7 @@ endif
|
|
|
|
|
|
|
|
# Temporary path to pack a file
|
|
# Temporary path to pack a file
|
|
|
ifndef PACKDIR
|
|
ifndef PACKDIR
|
|
|
-ifndef inlinux
|
|
|
|
|
|
|
+ifndef inUnix
|
|
|
PACKDIR=$(BASEDIR)/pack_tmp
|
|
PACKDIR=$(BASEDIR)/pack_tmp
|
|
|
else
|
|
else
|
|
|
PACKDIR=/tmp/fpc-pack
|
|
PACKDIR=/tmp/fpc-pack
|
|
@@ -960,7 +1091,7 @@ endif
|
|
|
|
|
|
|
|
# Use tar by default under linux
|
|
# Use tar by default under linux
|
|
|
ifndef USEZIP
|
|
ifndef USEZIP
|
|
|
-ifdef inlinux
|
|
|
|
|
|
|
+ifdef inUnix
|
|
|
USETAR=1
|
|
USETAR=1
|
|
|
endif
|
|
endif
|
|
|
endif
|
|
endif
|
|
@@ -975,7 +1106,7 @@ ifdef USETAR
|
|
|
$(DEL) $(DESTZIPDIR)/$(ZIPNAME)$(TAREXT)
|
|
$(DEL) $(DESTZIPDIR)/$(ZIPNAME)$(TAREXT)
|
|
|
cd $(PACKDIR) ; $(TARPROG) c$(TAROPT) --file $(DESTZIPDIR)/$(ZIPNAME)$(TAREXT) * ; cd $(BASEDIR)
|
|
cd $(PACKDIR) ; $(TARPROG) c$(TAROPT) --file $(DESTZIPDIR)/$(ZIPNAME)$(TAREXT) * ; cd $(BASEDIR)
|
|
|
else
|
|
else
|
|
|
- $(DEL) $(DESTZIPDIR)/$(ZIPNAME)/$(ZIPEXT)
|
|
|
|
|
|
|
+ $(DEL) $(DESTZIPDIR)/$(ZIPNAME)$(ZIPEXT)
|
|
|
cd $(PACKDIR) ; $(ZIPPROG) -Dr $(ZIPOPT) $(DESTZIPDIR)/$(ZIPNAME)$(ZIPEXT) * ; cd $(BASEDIR)
|
|
cd $(PACKDIR) ; $(ZIPPROG) -Dr $(ZIPOPT) $(DESTZIPDIR)/$(ZIPNAME)$(ZIPEXT) * ; cd $(BASEDIR)
|
|
|
endif
|
|
endif
|
|
|
$(DELTREE) $(PACKDIR)
|
|
$(DELTREE) $(PACKDIR)
|
|
@@ -986,27 +1117,35 @@ endif
|
|
|
fpc_zipsourceinstall:
|
|
fpc_zipsourceinstall:
|
|
|
$(MAKE) fpc_zipinstall ZIPTARGET=sourceinstall PACKAGESUFFIX=src
|
|
$(MAKE) fpc_zipinstall ZIPTARGET=sourceinstall PACKAGESUFFIX=src
|
|
|
|
|
|
|
|
|
|
+.PHONY: fpc_zipexampleinstall
|
|
|
|
|
+
|
|
|
|
|
+fpc_zipexampleinstall:
|
|
|
|
|
+ $(MAKE) fpc_zipinstall ZIPTARGET=exampleinstall PACKAGESUFFIX=exm
|
|
|
|
|
+
|
|
|
#####################################################################
|
|
#####################################################################
|
|
|
# Clean rules
|
|
# Clean rules
|
|
|
#####################################################################
|
|
#####################################################################
|
|
|
|
|
|
|
|
-.PHONY: fpc_clean fpc_cleanall
|
|
|
|
|
|
|
+.PHONY: fpc_clean fpc_cleanall fpc_distclean
|
|
|
|
|
|
|
|
ifdef EXTRACLEANUNITS
|
|
ifdef EXTRACLEANUNITS
|
|
|
override CLEANPPUFILES+=$(addsuffix $(PPUEXT),$(EXTRACLEANUNITS))
|
|
override CLEANPPUFILES+=$(addsuffix $(PPUEXT),$(EXTRACLEANUNITS))
|
|
|
endif
|
|
endif
|
|
|
|
|
|
|
|
ifdef CLEANPPUFILES
|
|
ifdef CLEANPPUFILES
|
|
|
|
|
+override CLEANPPUFILES:=$(addprefix $(TARGETDIRPREFIX),$(CLEANPPUFILES))
|
|
|
|
|
+# Get the .o and .a files created for the units
|
|
|
ifdef PPUFILES
|
|
ifdef PPUFILES
|
|
|
CLEANPPULINKFILES:=$(shell $(PPUFILES) $(CLEANPPUFILES))
|
|
CLEANPPULINKFILES:=$(shell $(PPUFILES) $(CLEANPPUFILES))
|
|
|
else
|
|
else
|
|
|
-CLEANPPULINKFILES:=$(wildcard $(subst $(PPUEXT),$(OEXT),$(CLEANPPUFILES)))
|
|
|
|
|
|
|
+CLEANPPULINKFILES:=$(wildcard $(subst $(PPUEXT),$(OEXT),$(CLEANPPUFILES)) $(addprefix $(LIBPREFIX),$(subst $(PPUEXT),$(STATICLIBEXT),$(CLEANPPUFILES))))
|
|
|
endif
|
|
endif
|
|
|
|
|
+override CLEANPPULINKFILES:=$(addprefix $(TARGETDIRPREFIX),$(CLEANPPULINKFILES))
|
|
|
endif
|
|
endif
|
|
|
|
|
|
|
|
fpc_clean: $(CLEANTARGET)
|
|
fpc_clean: $(CLEANTARGET)
|
|
|
ifdef CLEANEXEFILES
|
|
ifdef CLEANEXEFILES
|
|
|
- -$(DEL) $(CLEANEXEFILES)
|
|
|
|
|
|
|
+ -$(DEL) $(addprefix $(TARGETDIRPREFIX),$(CLEANEXEFILES))
|
|
|
endif
|
|
endif
|
|
|
ifdef CLEANPPUFILES
|
|
ifdef CLEANPPUFILES
|
|
|
-$(DEL) $(CLEANPPUFILES)
|
|
-$(DEL) $(CLEANPPUFILES)
|
|
@@ -1015,20 +1154,31 @@ ifneq ($(CLEANPPULINKFILES),)
|
|
|
-$(DEL) $(CLEANPPULINKFILES)
|
|
-$(DEL) $(CLEANPPULINKFILES)
|
|
|
endif
|
|
endif
|
|
|
ifdef CLEANRSTFILES
|
|
ifdef CLEANRSTFILES
|
|
|
- -$(DEL) $(CLEANRSTFILES)
|
|
|
|
|
|
|
+ -$(DEL) $(addprefix $(UNITTARGETDIRPREFIX),$(CLEANRSTFILES))
|
|
|
endif
|
|
endif
|
|
|
ifdef EXTRACLEANFILES
|
|
ifdef EXTRACLEANFILES
|
|
|
-$(DEL) $(EXTRACLEANFILES)
|
|
-$(DEL) $(EXTRACLEANFILES)
|
|
|
endif
|
|
endif
|
|
|
- -$(DEL) $(FPCMADE) $(PPAS) link.res $(FPCEXTCMD) $(REDIRFILE)
|
|
|
|
|
|
|
+ifdef LIBNAME
|
|
|
|
|
+ -$(DEL) $(LIBNAME) $(LIBFULLNAME)
|
|
|
|
|
+endif
|
|
|
|
|
+ -$(DEL) $(FPCMADE) $(PPAS) link.res $(FPCEXTFILE) $(REDIRFILE)
|
|
|
|
|
+
|
|
|
|
|
+fpc_distclean: fpc_clean
|
|
|
|
|
+
|
|
|
|
|
+# Also run clean first if targetdir is set. Unittargetdir is always
|
|
|
|
|
+# set if targetdir or unittargetdir is specified
|
|
|
|
|
+ifdef UNITTARGETDIR
|
|
|
|
|
+TARGETDIRCLEAN=fpc_clean
|
|
|
|
|
+endif
|
|
|
|
|
|
|
|
-fpc_cleanall: $(CLEANTARGET)
|
|
|
|
|
|
|
+fpc_cleanall: $(CLEANTARGET) $(TARGETDIRCLEAN)
|
|
|
ifdef CLEANEXEFILES
|
|
ifdef CLEANEXEFILES
|
|
|
-$(DEL) $(CLEANEXEFILES)
|
|
-$(DEL) $(CLEANEXEFILES)
|
|
|
endif
|
|
endif
|
|
|
-$(DEL) *$(OEXT) *$(PPUEXT) *$(RSTEXT) *$(ASMEXT) *$(STATICLIBEXT) *$(SHAREDLIBEXT) *$(PPLEXT)
|
|
-$(DEL) *$(OEXT) *$(PPUEXT) *$(RSTEXT) *$(ASMEXT) *$(STATICLIBEXT) *$(SHAREDLIBEXT) *$(PPLEXT)
|
|
|
-$(DELTREE) *$(SMARTEXT)
|
|
-$(DELTREE) *$(SMARTEXT)
|
|
|
- -$(DEL) $(FPCMADE) $(PPAS) link.res $(FPCEXTCMD) $(REDIRFILE)
|
|
|
|
|
|
|
+ -$(DEL) $(FPCMADE) $(PPAS) link.res $(FPCEXTFILE) $(REDIRFILE)
|
|
|
|
|
|
|
|
#####################################################################
|
|
#####################################################################
|
|
|
# Info rules
|
|
# Info rules
|