Browse Source

* merged install/Makefile

peter 25 years ago
parent
commit
7d8cbbccfb
2 changed files with 804 additions and 113 deletions
  1. 452 68
      base/Makefile
  2. 352 45
      base/Makefile.fpc

+ 452 - 68
base/Makefile

@@ -1,8 +1,8 @@
 #
-# Makefile generated by fpcmake v0.99.13 [2000/02/02]
+# Makefile generated by fpcmake v0.99.13 [2000/02/07]
 #
 
-defaultrule: info
+defaultrule: help
 
 #####################################################################
 # Autodetect OS (Linux or Dos or Windows NT)
@@ -113,6 +113,87 @@ endif
 
 export FPC OS_TARGET OS_SOURCE CPU_TARGET CPU_SOURCE FPC_VERSION
 
+#####################################################################
+# Pre Settings
+#####################################################################
+
+OLDFPCDIR:=$(FPCDIR)
+
+checkfpcdir:
+ifdef OLDFPCDIR
+ifneq ($(OLDFPCDIR),)
+FPCDIRSET=fpcdirset
+fpcdirset:
+	@echo ---------------------------------------------------------
+	@echo
+	@echo   You must unset FPCDIR to use this the packaging rules.
+	@echo
+	@echo ---------------------------------------------------------
+	@cantcontinuewithfpcdir
+endif
+endif
+
+# Check if install/ subdir is available
+ifneq ($(wildcard install),)
+CVSINSTALL=install
+else
+CVSINSTALL=.
+endif
+
+# All target
+ifdef SNAPSHOT
+ALLTARGET=all
+else
+ifndef ALLTARGET
+ifeq ($(OS_TARGET),win32)
+ALLTARGET=smart
+else
+ifeq ($(OS_TARGET),go32v2)
+ALLTARGET=smart
+else
+ALLTARGET=all
+endif
+endif
+endif
+endif
+
+# Prefix for units
+ifeq ($(OS_TARGET),linux)
+PKGPRE=units
+else
+PKGPRE=u
+endif
+
+# Test dir if none specified
+ifndef PREFIXINSTALLDIR
+ifdef inlinux
+PREFIXINSTALLDIR=/tmp/pptest
+else
+PREFIXINSTALLDIR=/pptest
+endif
+endif
+
+# Always compile for release
+override RELEASE=1
+export RELEASE
+
+# Temporary path to pack a file
+BASEPACKDIR=$(BASEDIR)/basepack
+
+# Use new ppc386
+PPNEW=$(BASEDIR)/compiler/ppc386$(EXEEXT)
+
+# Don't use ppufiles for win32 becuase of commandline length problems
+ifneq ($(OS_TARGET),win32)
+PPUFILESNEW=$(BASEDIR)/utils/ppufiles$(EXEEXT)
+endif
+
+# Build/install options
+BUILDOPTS=FPC=$(PPNEW) RELEASE=1
+INSTALLOPTS=FPC=$(PPNEW) ZIPDESTDIR=$(BASEDIR)
+ifdef PPUFILESNEW
+override INSTALLOPT+=PPUFILES=$(PPUFILESNEW)
+endif
 #####################################################################
 # FPCDIR Setting
 #####################################################################
@@ -129,16 +210,6 @@ else
 override FPCDIR=wrong
 endif
 
-# Default FPCDIR
-ifeq ($(FPCDIR),wrong)
-override FPCDIR=$(BASEDIR)
-ifeq ($(wildcard $(FPCDIR)/rtl),)
-ifeq ($(wildcard $(FPCDIR)/units),)
-override FPCDIR=wrong
-endif
-endif
-endif
-
 # Detect FPCDIR
 ifeq ($(FPCDIR),wrong)
 ifdef inlinux
@@ -190,12 +261,6 @@ ZIPTARGET=install
 # Libraries
 
 
-#####################################################################
-# Post Settings
-#####################################################################
-
-export RELEASE=1
-
 #####################################################################
 # Shell tools
 #####################################################################
@@ -304,6 +369,61 @@ else
 LDCONFIG=
 endif
 
+# ppufiles
+ifndef PPUFILES
+PPUFILES:=$(strip $(wildcard $(addsuffix /ppufiles$(EXEEXT),$(SEARCHPATH))))
+ifeq ($(PPUFILES),)
+PPUFILES=
+else
+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)
+ifndef UPXPROG
+ifeq ($(OS_TARGET),go32v2)
+UPXPROG:=1
+endif
+ifeq ($(OS_TARGET),win32)
+UPXPROG:=1
+endif
+ifdef UPXPROG
+UPXPROG:=$(strip $(wildcard $(addsuffix /upx$(EXEEXT),$(SEARCHPATH))))
+ifeq ($(UPXPROG),)
+UPXPROG=
+else
+UPXPROG:=$(firstword $(UPXPROG))
+endif
+else
+UPXPROG=
+endif
+endif
+export UPXPROG
+
+# gdate/date
+ifndef DATE
+DATE:=$(strip $(wildcard $(addsuffix /date$(EXEEXT),$(SEARCHPATH))))
+ifeq ($(DATE),)
+DATE:=$(strip $(wildcard $(addsuffix /gdate$(EXEEXT),$(SEACHPATH))))
+ifeq ($(DATE),)
+DATE=
+else
+DATE:=$(firstword $(DATE))
+endif
+else
+DATE:=$(firstword $(DATE))
+endif
+endif
+export DATE
+
+ifdef DATE
+DATESTR:=$(shell $(DATE) +%Y%m%d)
+else
+DATESTR=
+endif
+
 # ZipProg, you can't use Zip as the var name (PFV)
 ifndef ZIPPROG
 ZIPPROG:=$(strip $(wildcard $(addsuffix /zip$(EXEEXT),$(SEARCHPATH))))
@@ -527,8 +647,6 @@ endif
 # Standard rules
 #####################################################################
 
-all: $(addsuffix _all,$(DIROBJECTS))
-
 debug: $(addsuffix _debug,$(DIROBJECTS))
 
 examples: $(addsuffix _examples,$(DIROBJECTS))
@@ -541,23 +659,15 @@ shared: $(addsuffix _shared,$(DIROBJECTS))
 
 showinstall: $(addsuffix _showinstall,$(DIROBJECTS))
 
-install: $(addsuffix _install,$(DIROBJECTS))
-
 sourceinstall: $(addsuffix _sourceinstall,$(DIROBJECTS))
 
-zipinstall: fpc_zipinstall
-
 zipsourceinstall: fpc_zipsourceinstall
 
-clean: $(addsuffix _clean,$(DIROBJECTS))
-
-distclean: $(addsuffix _distclean,$(DIROBJECTS))
-
-cleanall: $(addsuffix _cleanall,$(DIROBJECTS))
+cleanall: fpc_cleanall $(addsuffix _cleanall,$(DIROBJECTS))
 
 require: $(addsuffix _require,$(DIROBJECTS))
 
-.PHONY:  all debug examples test smart shared showinstall install sourceinstall zipinstall zipsourceinstall clean distclean cleanall require
+.PHONY:  debug examples test smart shared showinstall sourceinstall zipsourceinstall cleanall require
 
 #####################################################################
 # Zip
@@ -615,6 +725,52 @@ endif
 	$(DELTREE) $(PACKDIR)
 endif
 
+#####################################################################
+# Clean rules
+#####################################################################
+
+.PHONY: fpc_clean fpc_cleanall fpc_distclean
+
+ifdef EXTRACLEANUNITS
+override CLEANPPUFILES+=$(addsuffix $(PPUEXT),$(EXTRACLEANUNITS))
+endif
+
+ifdef CLEANPPUFILES
+ifdef PPUFILES
+CLEANPPULINKFILES:=$(shell $(PPUFILES) $(CLEANPPUFILES))
+else
+CLEANPPULINKFILES:=$(wildcard $(subst $(PPUEXT),$(OEXT),$(CLEANPPUFILES)))
+endif
+endif
+
+fpc_clean: $(CLEANTARGET)
+ifdef CLEANEXEFILES
+	-$(DEL) $(CLEANEXEFILES)
+endif
+ifdef CLEANPPUFILES
+	-$(DEL) $(CLEANPPUFILES)
+endif
+ifneq ($(CLEANPPULINKFILES),)
+	-$(DEL) $(CLEANPPULINKFILES)
+endif
+ifdef CLEANRSTFILES
+	-$(DEL) $(CLEANRSTFILES)
+endif
+ifdef EXTRACLEANFILES
+	-$(DEL) $(EXTRACLEANFILES)
+endif
+	-$(DEL) $(FPCMADE) $(PPAS) link.res $(FPCEXTFILE) $(REDIRFILE)
+
+fpc_distclean: fpc_clean
+
+fpc_cleanall: $(CLEANTARGET)
+ifdef CLEANEXEFILES
+	-$(DEL) $(CLEANEXEFILES)
+endif
+	-$(DEL) *$(OEXT) *$(PPUEXT) *$(RSTEXT) *$(ASMEXT) *$(STATICLIBEXT) *$(SHAREDLIBEXT) *$(PPLEXT)
+	-$(DELTREE) *$(SMARTEXT)
+	-$(DEL) $(FPCMADE) $(PPAS) link.res $(FPCEXTFILE) $(REDIRFILE)
+
 #####################################################################
 # Directories
 #####################################################################
@@ -1072,26 +1228,28 @@ endif
 # Users rules
 #####################################################################
 
+# These values can change
+unexport FPC_VERSION OS_SOURCE
+
 #####################################################################
 # Main targets
 #####################################################################
 
-.PHONY: compiler_cycle \
-	idezips ide_allzip ide_gdbzip ide_fullzip ide_fullgdbzip \
-	fclzip gtkzip fvzip compilerzip utilszip
-
-info:
+.PHONY: help checkfpcdir
+	
+help:
 	@echo
-	@echo Please use one of the following targets:
+	@echo Directory targets:
 	@echo
 	@echo $(DIROBJECTS)
 	@echo
-	@echo All targets can follow after a _ with:
-	@echo all,clean,install,staticinstall,sharedinstall
+	@echo Packing targets are:
+	@echo
+	@echo go32v2zip,win32zip,linuxzip,sourcezip
 	@echo
-	@echo example: make api_staticinstall
 	@exit
 
+
 #####################################################################
 # Dependencies
 #####################################################################
@@ -1100,6 +1258,8 @@ info:
 # Compiler
 #######################################
 
+.PHONY: compiler_cycle
+
 compiler_cycle:
 	$(MAKE) -C compiler cycle
 
@@ -1107,13 +1267,12 @@ compiler_cycle:
 # IDE
 #######################################
 
-ide_gdb:
-	$(MAKE) -C ide gdb
+.PHONY: ide_comp ide_full
 
-ide_full:
+ide_comp:
 	$(MAKE) -C ide full
 
-ide_fullgdb:
+ide_full:
 	$(MAKE) -C ide fullgdb
 
 
@@ -1122,13 +1281,13 @@ ide_fullgdb:
 #######################################
 
 demo_install:
-	$(MAKE) -C demo installexamples
+	$(MAKE) -C $(CVSINSTALL)/demo installexamples
 
 man_install:
-	$(MAKE) -C man installman
+	$(MAKE) -C $(CVSINSTALL)/man installman
 
 doc_install:
-	$(MAKE) -C doc installdoc
+	$(MAKE) -C $(CVSINSTALL)/doc installdoc
 
 
 #######################################
@@ -1159,28 +1318,253 @@ ide_fullgdbzip:
 	$(MAKE) ide_fullgdb
 	$(MAKE) -C ide/text zipinstall ZIPNAME=ide-full-$(PACKAGESUFFIX)
 
-fvzip: rtl_clean
-	$(MAKE) api_clean
-	$(MAKE) fv_clean
-	$(MAKE) fv_all
-	$(MAKE) zipinstall ZIPTARGET='api_install fv_install' ZIPNAME=fv-$(PACKAGESUFFIX)
-
-gtkzip: rtl_clean
-	$(MAKE) -C packages gtk_clean
-	$(MAKE) -C packages gtk_all
-	$(MAKE) -C packages gtk_zipinstall ZIPNAME=gtk-$(PACKAGESUFFIX)
-
-compilerzip: compiler_clean rtl_clean
-	$(MAKE) rtl_all
-	$(MAKE) compiler_all
+
+##########################################################################
+# Install
+##########################################################################
+
+.PHONY: installer
+
+INSTALLERBUILDDIR=fpinst
+
+installer:
+	$(COPYTREE) $(CVSINSTALL)/fpinst $(INSTALLERBUILDDIR)
+	$(MAKE) -C $(INSTALLERBUILDDIR) all RELEASE=1
+	$(MOVE) $(INSTALLERBUILDDIR)/install.exe .
+ifdef UPXPROG
+	-$(UPXPROG) install.exe
+endif
+	$(DELTREE) $(INSTALLERBUILDDIR)
+
+installersrc:
+	$(COPYTREE) fpinst $(INSTALLERBUILDDIR)
+	$(MAKE) -C $(INSTALLERBUILDDIR) zipsourceinstall
+	$(DELTREE) $(INSTALLERBUILDDIR)
+
+
+##########################################################################
+# Packaging
+##########################################################################
+
+.PHONY: all clean build installbase zipinstall zipinstallbase zipinstallfcl \
+	zipinstallpackages
+
+export RELEASE DESTZIPDIR
+
+all: build
+
+clean: $(addsuffix _distclean,$(DIROBJECTS))
+	$(DEL) build-stamp
+
+distclean: clean
+
+
+build: build-stamp
+build-stamp:
+# create new compiler
+	$(MAKE) compiler_cycle
+# clean
 	$(MAKE) rtl_clean
-	$(MAKE) rtl_all FPC=$(BASEDIR)/compiler/ppc386
-	$(MAKE) zipinstall ZIPTARGET='compiler_install rtl_install' ZIPNAME=compiler-$(PACKAGESUFFIX)
+	$(MAKE) api_clean
+	$(MAKE) fcl_clean
+	$(MAKE) packages_clean
+	$(MAKE) utils_clean
+# build everything
+	$(MAKE) rtl_$(ALLTARGET) $(BUILDOPTS)
+	$(MAKE) api_$(ALLTARGET) $(BUILDOPTS)
+	$(MAKE) fcl_$(ALLTARGET) $(BUILDOPTS)
+	$(MAKE) packages_$(ALLTARGET) $(BUILDOPTS)
+	$(MAKE) utils_all $(BUILDOPTS)
+
+	$(ECHO) Build > build-stamp
+
+installbase: build-stamp
+# create dirs
+	$(MKDIR) $(BASEINSTALLDIR)
+	$(MKDIR) $(DOCINSTALLDIR)
+	$(MKDIR) $(BININSTALLDIR)
+# readme & whatsnew and docs
+	$(COPY) $(CVSINSTALL)/doc/*.txt $(CVSINSTALL)/doc/copying* $(CVSINSTALL)/doc/faq.* $(DOCINSTALLDIR)
+# bingo32 (cwsdpmi,wmemu387.dxe)
+ifeq ($(OS_TARGET),go32v2)
+	$(COPY) $(CVSINSTALL)/bingo32/* $(BININSTALLDIR)
+endif
+# binw32 (cygwin1.dll)
+ifeq ($(OS_TARGET),win32)
+	$(COPY) $(CVSINSTALL)/binw32/* $(BININSTALLDIR)
+endif# manpages for linux
+ifeq ($(OS_TARGET),linux)
+	$(MAKE) -C $(CVSINSTALL)/man installman
+endif
+# install generated things
+	$(MAKE) compiler_install $(INSTALLOPTS)
+	$(MAKE) rtl_install $(INSTALLOPTS)
+
+install: build-stamp
+	$(MAKE) installbase $(INSTALLOPTS)
+	$(MAKE) utils_install $(INSTALLOPTS)
+	$(MAKE) api_install $(INSTALLOPTS)
+	$(MAKE) fcl_install $(INSTALLOPTS)
+	$(MAKE) packages_install $(INSTALLOPTS)
+
+zipinstall: $(FPCDIRSET) build-stamp
+	$(MAKE) fpc_zipinstall ZIPTARGET=installbase PACKAGENAME=base $(INSTALLOPTS)
+	$(MAKE) utils_zipinstall $(INSTALLOPTS)
+	$(MAKE) api_zipinstall $(INSTALLOPTS) PACKAGEPREFIX=$(PKGPRE)
+	$(MAKE) fcl_zipinstall $(INSTALLOPTS) PACKAGEPREFIX=$(PKGPRE)
+	$(MAKE) packages_zipinstall $(INSTALLOPTS) PACKAGEPREFIX=$(PKGPRE)
+
+
+##########################################################################
+# Docs
+##########################################################################
+
+.PHONY: docspdf docs docsrcinstall docsrc
+
+docspdf:
+	$(MAKE) -C docs pdfinstall
+
+docs:
+	$(MAKE) fpc_zipinstall ZIPTARGET=docspdf ZIPNAME=docs
+
+docsrcinstall:
+	$(MAKE) -C docs clean
+	$(MKDIR) $(SOURCEINSTALLDIR)
+	$(COPYTREE) docs $(SOURCEINSTALLDIR)
+
+docsrc:
+	$(MAKE) fpc_zipinstall ZIPTARGET=docsrcinstall ZIPNAME=docsrc
+
 
-fclzip: rtl_clean fcl_clean
-	$(MAKE) fcl_all
-	$(MAKE) fcl_zipinstall ZIPNAME=fcl-$(PACKAGESUFFIX)
+##########################################################################
+# Demos
+##########################################################################
 
-utilszip: utils_clean rtl_clean fcl_clean
-	$(MAKE) utils_all
-	$(MAKE) utils_zipinstall ZIPNAME=utils-$(PACKAGESUFFIX)
+.PHONY: demo demoinstall
+
+demoinstall:
+	$(COPYTREE) $(CVSINSTALL)/demo $(PREFIXINSTALLDIR)
+
+demo:
+	$(MAKE) fpc_zipinstall ZIPTARGET=demoinstall ZIPNAME=demo
+
+
+
+##########################################################################
+# Source targets
+##########################################################################
+
+sourcebase:
+# base Makefiles needed for sources
+	$(MKDIR) $(SOURCEINSTALLDIR)
+	$(MKDIR) $(SOURCEINSTALLDIR)/rtl
+	$(MKDIR) $(SOURCEINSTALLDIR)/packages
+	$(COPY) Makefile*  $(SOURCEINSTALLDIR)
+	$(COPY) rtl/Makefile* $(SOURCEINSTALLDIR)/rtl
+	$(COPY) packages/Makefile* $(SOURCEINSTALLDIR)/packages
+
+zipsource:
+	$(MAKE) fpc_zipinstall ZIPTARGET=sourcebase ZIPNAME=basesrc
+	$(MAKE) compiler_zipsourceinstall
+	$(MAKE) rtl_zipsourceinstall
+	$(MAKE) api_zipsourceinstall
+	$(MAKE) fcl_zipsourceinstall
+	$(MAKE) packages_zipsourceinstall
+	$(MAKE) utils_zipsourceinstall
+#        $(MAKE) installersrc
+#        $(MAKE) docsrc
+
+
+##########################################################################
+# OS targets
+##########################################################################
+
+.PHONY: go32v2 win32 linux go32v2zip win32zip linuxzip
+
+go32v2:
+	$(MAKE) install OS_TARGET=go32v2
+
+win32:
+	$(MAKE) install OS_TARGET=win32
+
+linux:
+	$(MAKE) install OS_TARGET=linux
+
+go32v2zip:
+	$(MAKE) zipinstall OS_TARGET=go32v2
+
+win32zip:
+	$(MAKE) zipinstall OS_TARGET=win32
+
+linuxzip:
+	$(MAKE) zipinstall OS_TARGET=linux
+
+
+##########################################################################
+# Debian / RPM
+##########################################################################
+
+.PHONY: debcopy deb rpmcopy rpm
+
+DEBSRCDIR:=/usr/src/fpc-$(FPC_VERSION)
+debcopy: distclean
+	rm -rf $(DEBSRCDIR)
+	install -d $(DEBSRCDIR)
+	$(COPYTREE) compiler $(DEBSRCDIR)
+	$(COPYTREE) rtl $(DEBSRCDIR)
+	$(COPYTREE) fcl $(DEBSRCDIR)
+	$(COPYTREE) api $(DEBSRCDIR)
+	$(COPYTREE) packages $(DEBSRCDIR)
+	$(COPYTREE) utils $(DEBSRCDIR)
+	$(COPYTREE) logs $(DEBSRCDIR)
+	$(COPYTREE) docs $(DEBSRCDIR)
+	$(COPYTREE) base/Makefile* $(DEBSRCDIR)
+	$(COPYTREE) $(CVSINSTALL)/debian $(DEBSRCDIR)
+	$(COPYTREE) $(CVSINSTALL)/man $(DEBSRCDIR)
+	$(COPYTREE) $(CVSINSTALL)/doc $(DEBSRCDIR)
+	$(COPYTREE) $(CVSINSTALL)/demo $(DEBSRCDIR)
+	find $(DEBSRCDIR) -name 'CVS*' | xargs -n1 rm -rf
+	chmod 755 $(DEBSRCDIR)/debian/rules
+
+deb: debcopy
+	cd $(DEBSRCDIR) ; debian/rules binary
+
+
+REDHATDIR=/usr/src/redhat
+RPMSOURCESDIR:=$(REDHATDIR)/SOURCES
+RPMSPECDIR:=$(REDHATDIR)/SPECS
+RPMSRCDIR:=$(RPMSOURCESDIR)/fpc
+DOCSRCDIR:=$(RPMSOURCESDIR)/fpcdoc
+rpmcopy: distclean
+	install -d $(REDHATDIR)
+	install -d $(RPMSPECDIR)
+	install -d $(RPMSOURCESDIR)
+# fpc.rpm
+	rm -rf $(RPMSRCDIR)
+	cp $(CVSINSTALL)/fpc-$(FPC_VERSION).spec $(RPMSPECDIR)
+	install -d $(RPMSRCDIR)
+	$(COPYTREE) compiler $(RPMSRCDIR)
+	$(COPYTREE) rtl $(RPMSRCDIR)
+	$(COPYTREE) fcl $(RPMSRCDIR)
+	$(COPYTREE) api $(RPMSRCDIR)
+	$(COPYTREE) packages $(RPMSRCDIR)
+	$(COPYTREE) utils $(RPMSRCDIR)
+	$(COPYTREE) logs $(RPMSRCDIR)
+	$(COPYTREE) base/Makefile* $(RPMSRCDIR)
+	$(COPYTREE) $(CVSINSTALL)/man $(RPMSRCDIR)
+	$(COPYTREE) $(CVSINSTALL)/doc $(RPMSRCDIR)
+	$(COPYTREE) $(CVSINSTALL)/demo $(RPMSRCDIR)
+	find $(RPMSRCDIR) -name 'CVS*' | xargs -n1 rm -rf
+	cd $(RPMSRCDIR) ; tar cvz * > $(RPMSOURCESDIR)/fpc-$(FPC_VERSION)-src.tar.gz
+# fpc-docs.rpm
+	rm -rf $(DOCSRCDIR)
+	cp $(CVSINSTALL)/fpc-docs-$(FPC_VERSION).spec $(RPMSPECDIR)
+	install -d $(DOCSRCDIR)
+	$(COPYTREE) docs $(DOCSRCDIR)
+	find $(DOCSRCDIR) -name 'CVS*' | xargs -n1 rm -rf
+	cd $(DOCSRCDIR) ; tar cvz * > $(RPMSOURCESDIR)/fpc-docs-$(FPC_VERSION)-src.tar.gz
+
+rpm: rpmcopy
+	cd $(RPMSPECDIR) ; rpm -ba fpc-$(FPC_VERSION).spec
+	cd $(RPMSPECDIR) ; rpm -ba fpc-docs-$(FPC_VERSION).spec
+	

+ 352 - 45
base/Makefile.fpc

@@ -6,43 +6,125 @@
 dirs=compiler rtl utils fcl api fv packages ide
 
 [defaults]
-defaultrule=info
+defaultrule=help
 
-[dirs]
-fpcdir=$(BASEDIR)
+[tools]
+toolzip=1
+toolupx=1
+tooldate=1
 
 [sections]
 none=1
 dirs=1
 tools=1
 exts=1
+clean=1
 zipinstall=1
 
-[postsettings]
-export RELEASE=1
+
+[presettings]
+OLDFPCDIR:=$(FPCDIR)
+
+checkfpcdir:
+ifdef OLDFPCDIR
+ifneq ($(OLDFPCDIR),)
+FPCDIRSET=fpcdirset
+fpcdirset:
+        @echo ---------------------------------------------------------
+        @echo
+        @echo   You must unset FPCDIR to use this the packaging rules.
+        @echo
+        @echo ---------------------------------------------------------
+        @cantcontinuewithfpcdir
+endif
+endif
+
+# Check if install/ subdir is available
+ifneq ($(wildcard install),)
+CVSINSTALL=install
+else
+CVSINSTALL=.
+endif
+
+# All target
+ifdef SNAPSHOT
+ALLTARGET=all
+else
+ifndef ALLTARGET
+ifeq ($(OS_TARGET),win32)
+ALLTARGET=smart
+else
+ifeq ($(OS_TARGET),go32v2)
+ALLTARGET=smart
+else
+ALLTARGET=all
+endif
+endif
+endif
+endif
+
+# Prefix for units
+ifeq ($(OS_TARGET),linux)
+PKGPRE=units
+else
+PKGPRE=u
+endif
+
+# Test dir if none specified
+ifndef PREFIXINSTALLDIR
+ifdef inlinux
+PREFIXINSTALLDIR=/tmp/pptest
+else
+PREFIXINSTALLDIR=/pptest
+endif
+endif
+
+# Always compile for release
+override RELEASE=1
+export RELEASE
+
+# Temporary path to pack a file
+BASEPACKDIR=$(BASEDIR)/basepack
+
+# Use new ppc386
+PPNEW=$(BASEDIR)/compiler/ppc386$(EXEEXT)
+
+# Don't use ppufiles for win32 becuase of commandline length problems
+ifneq ($(OS_TARGET),win32)
+PPUFILESNEW=$(BASEDIR)/utils/ppufiles$(EXEEXT)
+endif
+
+# Build/install options
+BUILDOPTS=FPC=$(PPNEW) RELEASE=1
+INSTALLOPTS=FPC=$(PPNEW) ZIPDESTDIR=$(BASEDIR)
+ifdef PPUFILESNEW
+override INSTALLOPT+=PPUFILES=$(PPUFILESNEW)
+endif
 
 
 [rules]
+# These values can change
+unexport FPC_VERSION OS_SOURCE
+
 #####################################################################
 # Main targets
 #####################################################################
 
-.PHONY: compiler_cycle \
-        idezips ide_allzip ide_gdbzip ide_fullzip ide_fullgdbzip \
-        fclzip gtkzip fvzip compilerzip utilszip
-
-info:
+.PHONY: help checkfpcdir
+	
+help:
+	@echo
+	@echo Directory targets:
+	@echo
+	@echo $(DIROBJECTS)
         @echo
-        @echo Please use one of the following targets:
+        @echo Packing targets are:
         @echo
-        @echo $(DIROBJECTS)
+        @echo go32v2zip,win32zip,linuxzip,sourcezip
         @echo
-        @echo All targets can follow after a _ with:
-        @echo all,clean,install,staticinstall,sharedinstall
-        @echo
-        @echo example: make api_staticinstall
         @exit
 
+
 #####################################################################
 # Dependencies
 #####################################################################
@@ -51,6 +133,8 @@ info:
 # Compiler
 #######################################
 
+.PHONY: compiler_cycle
+
 compiler_cycle:
         $(MAKE) -C compiler cycle
 
@@ -58,13 +142,12 @@ compiler_cycle:
 # IDE
 #######################################
 
-ide_gdb:
-        $(MAKE) -C ide gdb
+.PHONY: ide_comp ide_full
 
-ide_full:
+ide_comp:
         $(MAKE) -C ide full
 
-ide_fullgdb:
+ide_full:
         $(MAKE) -C ide fullgdb
 
 
@@ -73,13 +156,13 @@ ide_fullgdb:
 #######################################
 
 demo_install:
-        $(MAKE) -C demo installexamples
+        $(MAKE) -C $(CVSINSTALL)/demo installexamples
 
 man_install:
-        $(MAKE) -C man installman
+        $(MAKE) -C $(CVSINSTALL)/man installman
 
 doc_install:
-        $(MAKE) -C doc installdoc
+        $(MAKE) -C $(CVSINSTALL)/doc installdoc
 
 
 #######################################
@@ -110,29 +193,253 @@ ide_fullgdbzip:
         $(MAKE) ide_fullgdb
         $(MAKE) -C ide/text zipinstall ZIPNAME=ide-full-$(PACKAGESUFFIX)
 
-fvzip: rtl_clean
-        $(MAKE) api_clean
-        $(MAKE) fv_clean
-        $(MAKE) fv_all
-        $(MAKE) zipinstall ZIPTARGET='api_install fv_install' ZIPNAME=fv-$(PACKAGESUFFIX)
-
-gtkzip: rtl_clean
-        $(MAKE) -C packages gtk_clean
-        $(MAKE) -C packages gtk_all
-        $(MAKE) -C packages gtk_zipinstall ZIPNAME=gtk-$(PACKAGESUFFIX)
-
-compilerzip: compiler_clean rtl_clean
-        $(MAKE) rtl_all
-        $(MAKE) compiler_all
+
+##########################################################################
+# Install
+##########################################################################
+
+.PHONY: installer
+
+INSTALLERBUILDDIR=fpinst
+
+installer:
+        $(COPYTREE) $(CVSINSTALL)/fpinst $(INSTALLERBUILDDIR)
+        $(MAKE) -C $(INSTALLERBUILDDIR) all RELEASE=1
+        $(MOVE) $(INSTALLERBUILDDIR)/install.exe .
+ifdef UPXPROG
+        -$(UPXPROG) install.exe
+endif
+        $(DELTREE) $(INSTALLERBUILDDIR)
+
+installersrc:
+        $(COPYTREE) fpinst $(INSTALLERBUILDDIR)
+        $(MAKE) -C $(INSTALLERBUILDDIR) zipsourceinstall
+        $(DELTREE) $(INSTALLERBUILDDIR)
+
+
+##########################################################################
+# Packaging
+##########################################################################
+
+.PHONY: all clean build installbase zipinstall zipinstallbase zipinstallfcl \
+        zipinstallpackages
+
+export RELEASE DESTZIPDIR
+
+all: build
+
+clean: $(addsuffix _distclean,$(DIROBJECTS))
+	$(DEL) build-stamp
+
+distclean: clean
+
+
+build: build-stamp
+build-stamp:
+# create new compiler
+        $(MAKE) compiler_cycle
+# clean
         $(MAKE) rtl_clean
-        $(MAKE) rtl_all FPC=$(BASEDIR)/compiler/ppc386
-        $(MAKE) zipinstall ZIPTARGET='compiler_install rtl_install' ZIPNAME=compiler-$(PACKAGESUFFIX)
+        $(MAKE) api_clean
+        $(MAKE) fcl_clean
+        $(MAKE) packages_clean
+        $(MAKE) utils_clean
+# build everything
+        $(MAKE) rtl_$(ALLTARGET) $(BUILDOPTS)
+        $(MAKE) api_$(ALLTARGET) $(BUILDOPTS)
+        $(MAKE) fcl_$(ALLTARGET) $(BUILDOPTS)
+        $(MAKE) packages_$(ALLTARGET) $(BUILDOPTS)
+        $(MAKE) utils_all $(BUILDOPTS)
+
+        $(ECHO) Build > build-stamp
+
+installbase: build-stamp
+# create dirs
+        $(MKDIR) $(BASEINSTALLDIR)
+        $(MKDIR) $(DOCINSTALLDIR)
+        $(MKDIR) $(BININSTALLDIR)
+# readme & whatsnew and docs
+        $(COPY) $(CVSINSTALL)/doc/*.txt $(CVSINSTALL)/doc/copying* $(CVSINSTALL)/doc/faq.* $(DOCINSTALLDIR)
+# bingo32 (cwsdpmi,wmemu387.dxe)
+ifeq ($(OS_TARGET),go32v2)
+        $(COPY) $(CVSINSTALL)/bingo32/* $(BININSTALLDIR)
+endif
+# binw32 (cygwin1.dll)
+ifeq ($(OS_TARGET),win32)
+        $(COPY) $(CVSINSTALL)/binw32/* $(BININSTALLDIR)
+endif# manpages for linux
+ifeq ($(OS_TARGET),linux)
+        $(MAKE) -C $(CVSINSTALL)/man installman
+endif
+# install generated things
+        $(MAKE) compiler_install $(INSTALLOPTS)
+        $(MAKE) rtl_install $(INSTALLOPTS)
+
+install: build-stamp
+        $(MAKE) installbase $(INSTALLOPTS)
+        $(MAKE) utils_install $(INSTALLOPTS)
+        $(MAKE) api_install $(INSTALLOPTS)
+        $(MAKE) fcl_install $(INSTALLOPTS)
+        $(MAKE) packages_install $(INSTALLOPTS)
+
+zipinstall: $(FPCDIRSET) build-stamp
+        $(MAKE) fpc_zipinstall ZIPTARGET=installbase PACKAGENAME=base $(INSTALLOPTS)
+        $(MAKE) utils_zipinstall $(INSTALLOPTS)
+        $(MAKE) api_zipinstall $(INSTALLOPTS) PACKAGEPREFIX=$(PKGPRE)
+        $(MAKE) fcl_zipinstall $(INSTALLOPTS) PACKAGEPREFIX=$(PKGPRE)
+        $(MAKE) packages_zipinstall $(INSTALLOPTS) PACKAGEPREFIX=$(PKGPRE)
+
+
+##########################################################################
+# Docs
+##########################################################################
+
+.PHONY: docspdf docs docsrcinstall docsrc
+
+docspdf:
+        $(MAKE) -C docs pdfinstall
+
+docs:
+        $(MAKE) fpc_zipinstall ZIPTARGET=docspdf ZIPNAME=docs
+
+docsrcinstall:
+        $(MAKE) -C docs clean
+        $(MKDIR) $(SOURCEINSTALLDIR)
+        $(COPYTREE) docs $(SOURCEINSTALLDIR)
 
-fclzip: rtl_clean fcl_clean
-        $(MAKE) fcl_all
-        $(MAKE) fcl_zipinstall ZIPNAME=fcl-$(PACKAGESUFFIX)
+docsrc:
+        $(MAKE) fpc_zipinstall ZIPTARGET=docsrcinstall ZIPNAME=docsrc
 
-utilszip: utils_clean rtl_clean fcl_clean
-        $(MAKE) utils_all
-        $(MAKE) utils_zipinstall ZIPNAME=utils-$(PACKAGESUFFIX)
 
+##########################################################################
+# Demos
+##########################################################################
+
+.PHONY: demo demoinstall
+
+demoinstall:
+        $(COPYTREE) $(CVSINSTALL)/demo $(PREFIXINSTALLDIR)
+
+demo:
+        $(MAKE) fpc_zipinstall ZIPTARGET=demoinstall ZIPNAME=demo
+
+
+
+##########################################################################
+# Source targets
+##########################################################################
+
+sourcebase:
+# base Makefiles needed for sources
+        $(MKDIR) $(SOURCEINSTALLDIR)
+        $(MKDIR) $(SOURCEINSTALLDIR)/rtl
+        $(MKDIR) $(SOURCEINSTALLDIR)/packages
+        $(COPY) Makefile*  $(SOURCEINSTALLDIR)
+        $(COPY) rtl/Makefile* $(SOURCEINSTALLDIR)/rtl
+        $(COPY) packages/Makefile* $(SOURCEINSTALLDIR)/packages
+
+zipsource:
+        $(MAKE) fpc_zipinstall ZIPTARGET=sourcebase ZIPNAME=basesrc
+        $(MAKE) compiler_zipsourceinstall
+        $(MAKE) rtl_zipsourceinstall
+        $(MAKE) api_zipsourceinstall
+        $(MAKE) fcl_zipsourceinstall
+        $(MAKE) packages_zipsourceinstall
+        $(MAKE) utils_zipsourceinstall
+#        $(MAKE) installersrc
+#        $(MAKE) docsrc
+
+
+##########################################################################
+# OS targets
+##########################################################################
+
+.PHONY: go32v2 win32 linux go32v2zip win32zip linuxzip
+
+go32v2:
+        $(MAKE) install OS_TARGET=go32v2
+
+win32:
+        $(MAKE) install OS_TARGET=win32
+
+linux:
+        $(MAKE) install OS_TARGET=linux
+
+go32v2zip:
+        $(MAKE) zipinstall OS_TARGET=go32v2
+
+win32zip:
+        $(MAKE) zipinstall OS_TARGET=win32
+
+linuxzip:
+        $(MAKE) zipinstall OS_TARGET=linux
+
+
+##########################################################################
+# Debian / RPM
+##########################################################################
+
+.PHONY: debcopy deb rpmcopy rpm
+
+DEBSRCDIR:=/usr/src/fpc-$(FPC_VERSION)
+debcopy: distclean
+        rm -rf $(DEBSRCDIR)
+        install -d $(DEBSRCDIR)
+        $(COPYTREE) compiler $(DEBSRCDIR)
+        $(COPYTREE) rtl $(DEBSRCDIR)
+        $(COPYTREE) fcl $(DEBSRCDIR)
+        $(COPYTREE) api $(DEBSRCDIR)
+        $(COPYTREE) packages $(DEBSRCDIR)
+        $(COPYTREE) utils $(DEBSRCDIR)
+        $(COPYTREE) logs $(DEBSRCDIR)
+        $(COPYTREE) docs $(DEBSRCDIR)
+        $(COPYTREE) base/Makefile* $(DEBSRCDIR)
+        $(COPYTREE) $(CVSINSTALL)/debian $(DEBSRCDIR)
+        $(COPYTREE) $(CVSINSTALL)/man $(DEBSRCDIR)
+        $(COPYTREE) $(CVSINSTALL)/doc $(DEBSRCDIR)
+        $(COPYTREE) $(CVSINSTALL)/demo $(DEBSRCDIR)
+        find $(DEBSRCDIR) -name 'CVS*' | xargs -n1 rm -rf
+        chmod 755 $(DEBSRCDIR)/debian/rules
+
+deb: debcopy
+        cd $(DEBSRCDIR) ; debian/rules binary
+
+
+REDHATDIR=/usr/src/redhat
+RPMSOURCESDIR:=$(REDHATDIR)/SOURCES
+RPMSPECDIR:=$(REDHATDIR)/SPECS
+RPMSRCDIR:=$(RPMSOURCESDIR)/fpc
+DOCSRCDIR:=$(RPMSOURCESDIR)/fpcdoc
+rpmcopy: distclean
+	install -d $(REDHATDIR)
+	install -d $(RPMSPECDIR)
+	install -d $(RPMSOURCESDIR)
+# fpc.rpm
+        rm -rf $(RPMSRCDIR)
+        cp $(CVSINSTALL)/fpc-$(FPC_VERSION).spec $(RPMSPECDIR)
+        install -d $(RPMSRCDIR)
+        $(COPYTREE) compiler $(RPMSRCDIR)
+        $(COPYTREE) rtl $(RPMSRCDIR)
+        $(COPYTREE) fcl $(RPMSRCDIR)
+        $(COPYTREE) api $(RPMSRCDIR)
+        $(COPYTREE) packages $(RPMSRCDIR)
+        $(COPYTREE) utils $(RPMSRCDIR)
+        $(COPYTREE) logs $(RPMSRCDIR)
+        $(COPYTREE) base/Makefile* $(RPMSRCDIR)
+        $(COPYTREE) $(CVSINSTALL)/man $(RPMSRCDIR)
+        $(COPYTREE) $(CVSINSTALL)/doc $(RPMSRCDIR)
+        $(COPYTREE) $(CVSINSTALL)/demo $(RPMSRCDIR)
+        find $(RPMSRCDIR) -name 'CVS*' | xargs -n1 rm -rf
+        cd $(RPMSRCDIR) ; tar cvz * > $(RPMSOURCESDIR)/fpc-$(FPC_VERSION)-src.tar.gz
+# fpc-docs.rpm
+        rm -rf $(DOCSRCDIR)
+        cp $(CVSINSTALL)/fpc-docs-$(FPC_VERSION).spec $(RPMSPECDIR)
+        install -d $(DOCSRCDIR)
+        $(COPYTREE) docs $(DOCSRCDIR)
+        find $(DOCSRCDIR) -name 'CVS*' | xargs -n1 rm -rf
+        cd $(DOCSRCDIR) ; tar cvz * > $(RPMSOURCESDIR)/fpc-docs-$(FPC_VERSION)-src.tar.gz
+
+rpm: rpmcopy
+        cd $(RPMSPECDIR) ; rpm -ba fpc-$(FPC_VERSION).spec
+        cd $(RPMSPECDIR) ; rpm -ba fpc-docs-$(FPC_VERSION).spec
+