pkgmk(1)


pkgmk -- produce an installable package

Synopsis

pkgmk [-o] [-c] [-d device] [-r rootpath] [-b basedir] [-l limit] [-B blocksize] [-a arch] [-v version] [-p pstamp] [-f prototype] [variable=value ...] [pkginst]

Description

pkgmk produces an installable package to be used as input to the pkgadd command. The package contents will be in directory structure format. A package is a collection of related files and executables that can be independently installed.

The command uses the package prototype file as input and creates a pkgmap file. The contents for each entry in the prototype file is copied to the appropriate output location. Information concerning the contents (checksum, file size, modification date) is computed and stored in the pkgmap file, along with attribute information specified in the prototype file.


-o
Overwrites the same instance, package instance will be overwritten if it already exists.

-c
Compresses non-information files. You must also specify the -r option when using -c.

-k
Indicates that a key is required. This is equivalent to the entry of ACTKEY=YES in the pkginfo file.

-d device
Creates the package on device. device can be a full pathname to a directory or the identifier for a removable block device (for example, diskette1). The default device is the installation spool directory. The device named must already exist.

-r rootpath
Uses the indicated rootpath with the source pathname in the prototype file appended to locate objects on the source machine.

-b basedir
Prepends the indicated basedir to locate relocatable objects on the source machine.

-l limit
Specifies the maximum size in 512-byte blocks of the output device as limit. By default, if the output file is a directory or a mountable device, pkgmk will employ the df command to dynamically calculate the amount of available space on the output device. Useful in conjunction with pkgtrans to create package with datastream format.

-B blocksize
Block size of the actual destination of the package. Useful when the path specified with the -d option is only a temporary spool location and not the intended output for distribution. (Note, if distribution is to be in datastream format only, use -B 512.)

-a arch
Overrides the architecture information provided in the pkginfo file with arch.

-v version
Overrides version information provided in the pkginfo file with version.

-p pstamp
Overrides the production stamp definition in the pkginfo file with pstamp.

-f prototype
Uses the file prototype as input to the command. The default name for this file is either Prototype or prototype.

variable=value
Places the indicated variable in the packaging environment. [See prototype(4) for definitions of packaging variables.]

pkginst
A short string used to designate an abbreviation for the package name. pkgmk will automatically create a new instance if the version and/or architecture is different. A user should specify only a package abbreviation; a particular instance should not be specified unless the user is overwriting it.

Exit codes


0
Successful completion of script.

1
Fatal error. Installation process is terminated at this point.

99
Internal error.

Files


/usr/lib/locale/locale/LC_MESSAGES/uxpkg
language-specific message file [See LANG on environ(5).]

References

pkginfo(4), pkgparam(1), pkgproto(1), pkgtrans(1), setinfo(4)

Notices

Entries in the prototype file that reference relative paths above the rootpath specification will not be compressed.

When the -c option is specified, any !search commands found in the prototype(4) file.

Any files that were already compressed (that is, only those in ".Z" form) before being processed by pkgmk will not be uncompressed by the pkgadd command.

You can use pkgproto to create the prototype file. In this case, you must manually add in the entries for any installation scripts and files you are using in the package. You only need entries for those files and scripts that you use. However, you must always add an entry for the pkginfo file for the package. See pkgproto(1) for more information.

pkgmk does not work with tape devices.


© 2004 The SCO Group, Inc. All rights reserved.
UnixWare 7 Release 7.1.4 - 25 April 2004