Jonas Maebe 63b8ff87c8 * fixes for go32v2 compilation by John Lee (approved by Tomas) 16 years ago
..
examples f0c4849f3a * another example 18 years ago
lnet 0dce152199 * update lnet in fppkg to 0.5.8 18 years ago
Makefile 1bbc9b3e13 * implicit units in a Makefile.fpc are installed when doing a cross install, however if they are referenced only from a program they won't be build so a cross install fails: added build unit, resolves #14409 16 years ago
Makefile.fpc 1bbc9b3e13 * implicit units in a Makefile.fpc are installed when doing a cross install, however if they are referenced only from a program they won't be build so a cross install fails: added build unit, resolves #14409 16 years ago
README.txt 4bf254bc32 * added .txt extensions to all README, TODO and COPYING files 16 years ago
buildfppkg.pp 63b8ff87c8 * fixes for go32v2 compilation by John Lee (approved by Tomas) 16 years ago
fpmkunitsrc.inc c1a83273f7 * Use ExeSearch instead of FileSearch to find command executable 16 years ago
fppkg.lpi 7ab46e8507 * basic work to load installed versions from fpunits.conf 17 years ago
fppkg.pp 660a7c4b6d * Load the local mirrors before an update is tried if it is a new installation or else the update will always fail 16 years ago
fprepos.pp e60623bd33 * While parsing a string to abtain a version number the default build-number is set to 1. A value of 0 indicate that it is a pre-release like a release candidate. 2.2.4rcX will become 2.2.4-0 and 2.2.4 translates as 2.2.4-1 16 years ago
fpxmlrep.pp e8e9da4047 * replace showall with list command 16 years ago
pkgcommands.pp bfae5e097d * When IsSuperUser is true, use the GlobalUnitDir instead of the 16 years ago
pkgdownload.pp 85250cca06 * split repository in InstalledRepository and AvailableRepository 17 years ago
pkgfpmake.pp 514ccae231 * use random name for tempbuilddir 16 years ago
pkgglobals.pp e8e9da4047 * replace showall with list command 16 years ago
pkghandler.pp e8e9da4047 * replace showall with list command 16 years ago
pkglnet.pp ef9177ccc4 * report URL in download failure 17 years ago
pkgmessages.pp efeafa36aa * log configuration settings 17 years ago
pkgmkconv.pp 85250cca06 * split repository in InstalledRepository and AvailableRepository 17 years ago
pkgoptions.pp d4d733b173 * Use ExeSearch instead of FileSearch to find fpc executable 16 years ago
pkgrepos.pp b4616d43c1 * PackageAvailableVersionStr should use the AvailableRepository instead of InstalledRepository 16 years ago
pkgwget.pp ef9177ccc4 * report URL in download failure 17 years ago

README.txt

This is the FPC packager.

The architecture is as follows:

A mirror list is maintained with FPC repositories.
The packager will download the mirror list and store
it somewhere locally

From a mirror, a repository is chosen (using it's name)

From the repository the repository file is downloaded.
It contains all known packages. The fprepos.pp unit contains the
functionality to read and maintain the package file.

The packager maintains a local repository file. when needed
it will download a package and install it. It does so recursively.

Each package contains a fpmake.pp driver. It contains all that
is needed to compile, install and zip a package. It can also
create a manifest file (in XML) to import in a repository.

All packager functionality will be implemented in units so
these units can be used in command-line and GUI package managers.

All packager command handling is implemented in descendents fom
TPackageHandler (pkghandler.pp). All messages emitted by these
handlers are in pkgmessages.

Units:
-----

fprepos:
A unit that describes a repository.
It is mainly a collection of packages.
fpxmlrep
A unit to read/write a repository to XML. It can be used to read a
manifest file as produced by the fpmake driver.
pkgropts
A unit to maintain settings for the packager it reads/writes
options from/to an ini file.
fpmkunit
this is the unit that implements all the functionality a fpmake driver
needs.
fpmktype
types and constants shared by fpmkunit and fprepos
rep2xml
test program for the fprepos unit.
reptest
creates some test packages for use in the rep2xml test program.
fppkg
the package manager application
fpmkconv
Makefile.fpc to fpmake converter.
pkgmessages
the messages used in pkghandler and below.
pkghandler
the base for all fppkg command handlers
pkgdownload
a base implementation for download functionality in fppkg
pkgwget
a downloader based on spawning wget.
pkgsynapse
a downloader based on Synapse. Do not put in makefile, as Synapse is
not distributed by default with FPC.
pkglibcurl
a downloader based on LibCurl (plain C library).
pkgocurl
a downloader based on CurlPas (object version). Do not put in makefile,
as CurlPas is not distributed with FPC.
pkglnet
a downloader based on lNet. The library is distributed in "lnet" subdir
of fppkg root.


Options supported in packager config file:
------------------------------------------

LocalMirrors
Local file with list of mirrors.
RemoteMirrors
URL with location of remote mirrors file.
RemoteRepository
Name of repository as found in LocalMirrors file.
LocalRepository
Location of local repository file.
InstallDir
Directory to install packages/units to
BuildDir
Directory where to unpack and build packages
Compiler
Compiler binary to be used
OS
Default OS
CPU
Default CPU

Defaults can be found in pkgropts


Helpfull commands for building packages:
----------------------------------------

* Generate AddInclude and AddUnit lines from an existing PPU file:

ppudump | awk "/^Source/ { printf(\"AddInclude('%s');\\n\",\$5); } /^Uses unit/ { printf(\"AddUnit('%s');\\n\",tolower(\$3)); }"

* Testing if building a package from archive works:

fpc fpmake && fpmake archive && fppkg build *.zip

* Comparing units directories and generate AddUnit lines for missing .ppu files in :

diff -q | awk "/^Only.*ppu/ { gsub(\".ppu\",\".pp\"); printf(\"T:=P.Targets.AddUnit('%s');\n\",\$NF); }"