|
|
(522 intermediate revisions by 75 users not shown) |
Line 1: |
Line 1: |
| == Creating Package HOWTO == | | {{autolang|base=yes}} |
|
| |
|
| This page describes the mechanics of how to create an RPM package for Fedora (such as
| | {{admon/important|deprecated|As part of documentation move to docs.fp.o, this page has moved to https://docs.fedoraproject.org/en-US/quick-docs/creating-rpm-packages}} |
| how to create a .spec file). It also gives some practical warnings about stuff that will or won't work,
| |
| which may save you hours of time later.
| |
| This is ''not'' the list of official package guidelines for Fedora (though it ''should'' be compatible with them).
| |
| | |
| Nearly all Linux distributions can install and uninstall programs as "packages".
| |
| Fedora, and many other Linux distributions, use the "RPM" format for packages.
| |
| There are tools that make it easy to create RPM packages; the key is to write
| |
| a ".spec" file that explains to RPM how to build and install the program.
| |
| | |
| == Setting up ==
| |
| | |
| Before you create RPM packages on Fedora, you need to install some core
| |
| development tools and set up the account(s) you will use. As root:
| |
| # yum groupinstall "Development Tools"
| |
| # yum install rpmdevtools
| |
| | |
| It's strongly recommended that you create a new "dummy user" specifically for
| |
| creating rpm packages. That way, if something goes terribly wrong, the
| |
| program or build process can't trash your files, or
| |
| send your private files/keys to the world. At the very least,
| |
| you should normally ''not'' create your packages as user root.
| |
| You can create a new user named "makerpm" quickly by doing:
| |
| # /usr/sbin/useradd makerpm
| |
| | |
| Then log in as that special dummy user (makerpm).
| |
| | |
| Once you're logged in as the user who is creating packages,
| |
| create the directory structure in your home directory by executing:
| |
| $ rpmdev-setuptree
| |
| | |
| The "rpmdev-setuptree" program will create an "rpmbuild" directory in your $HOME
| |
| directory. Underneath "rpmbuild" are a set of subdirectories
| |
| (such as SPECS and BUILD), which you will use for creating your packages.
| |
| | |
| One you've set up your system and user account, you won't normally need
| |
| to do these again. | |
| | |
| == Setting up to package a particular program ==
| |
| | |
| If there are special programs that are required to build or run it, install them
| |
| and write down what they were (you'll need that information).
| |
| | |
| To package a program, you ''must'' package pristine (original) sources, along
| |
| with the patches and build instructions.
| |
| It's generally ''not'' okay to start with pre-compiled code.
| |
| Install the file with the original source (usually a .tar.gz file) in the
| |
| "~/rpmbuild/SOURCES" directory (of your "makerpm" account).
| |
| | |
| Read through the manual installation instructions for your program;
| |
| you're going to be automating this by editing a ".spec" file, so you have
| |
| to understand what you're supposed to do first. | |
| | |
| == Creating a spec file ==
| |
| | |
| You now need to create a ".spec" file in the "~/rpmbuild/SPECS" directory.
| |
| Generally, you'll name it after the program, e.g., "program.spec".
| |
| | |
| When you're creating a spec file for the first time, create its initial version using emacs or vim;
| |
| they will automatically create a template for you. E.G.:
| |
| $ cd ~/rpmbuild/SPECS
| |
| $ vi program.spec
| |
| | |
| The [http://docs.fedoraproject.org/drafts/rpm-guide-en/ch-creating-rpms.html RPM Guide, section on creating RPMs],
| |
| describes the details of how to fill in a spec file.
| |
| | |
| Some older documents about RPM have the most information, but older documents tend to assume that
| |
| all rpm work happens in a shared /usr/src/redhat directory. This is an obsolete way of
| |
| using rpm and ''not'' recommended.
| |
| | |
| '''Beware''': Comments (beginning with #) do not work as you might expect.
| |
| ''Do not'' include macros (words beginning with "%") in a comment, because they are expanded even inside comments;
| |
| if the macro is multi-line it cause weird errors.
| |
| Also, don't use in-line comments (a # not at the beginning of a line);
| |
| in-line comments often don't work properly in a spec file.
| |
| Instead, use a comment-only line (without macros).
| |
| | |
| [[Packaging/ScriptletSnippets|Scriptlet Snippets]] has some useful examples of scriptlets.
| |
| | |
| == Creating RPMs from the spec file ==
| |
| | |
| Once you've create a spec file, say "program.spec", you can create
| |
| source and binary RPMs by simply running this:
| |
| $ rpmbuild --clean -ba program.spec
| |
| | |
| When things go wrong, you can "cd" into the BUILD directory and see what's left over.
| |
| | |
| If it is successful, you'll find your binary RPM(s) in the "~/rpmbuild/RPMS/"
| |
| subdirectory, and the source RPM in "~/rpmbuild/SRPMS".
| |
| If you "cd" to the "~/rpmbuild/RPMS" directory, to the architecture subdirectory,
| |
| and then find some rpms, you can quickly see what's in each rpm by using rpmls:
| |
| $ rpmls *.rpm
| |
| | |
| If those look okay, you can become root and try to install them:
| |
| # rpm -ivp XYZ1.rpm XYZ2.rpm XYZ3.rpm ...
| |
| | |
| Then, you can test them out.
| |
| | |
| You can uninstall them later using:
| |
| # rpm -e XYZ1 XYZ2 XYZ3
| |
| | |
| == Guidelines and rules ==
| |
| | |
| When you create your packages, you'll need to follow the following rules and guidelines:
| |
| * [[PackageMaintainers/Join| How to join the Fedora Package Collection Maintainers]] - describes the process for becoming a Fedora package maintainer
| |
| * [[Packaging/Guidelines|Packaging Guidelines]]
| |
| * [[Packaging/NamingGuidelines| Package Naming Guidelines]]
| |
| * [[Packaging/DistTag| Dist Tag Guidelines]]
| |
| * [[Packaging/ReviewGuidelines| Package Review Guidelines]]
| |
| | |
| == For more information ==
| |
| | |
| The [[PackageMaintainers|Package Maintainers]] page links to many other useful pages, and the
| |
| The [[PackageMaintainers/UpdatingPackageHowTo|Updating Package HOWTO]] describes how to update
| |
| an existing package you already maintain in Fedora.
| |
| | |
| For more information, outside of the Fedora Wiki, see:
| |
| * [http://www.g-loaded.eu/2006/04/05/how-to-build-rpm-packages-on-fedora/ How to build RPM packages on Fedora] - quick run-through
| |
| * Packaging software with RPM (developerWorks) [http://www.ibm.com/developerworks/library/l-rpm1/ Part 1] and [http://www.ibm.com/developerworks/library/l-rpm2/ Part 2]
| |
| * [http://www.redhatmagazine.com/2008/02/28/when-sally-met-eddie-the-fedora-package-story/ When Sally met Eddie]
| |
| * [http://rpm.org/max-rpm-snapshot/ Maximum RPM Book]
| |
| * [http://docs.fedoraproject.org/drafts/rpm-guide-en/ch-creating-rpms.html RPM Guide, section on creating RPMs]
| |
| * [http://docs.fedoraproject.org/developers-guide/ch-rpm-building.html Developer's guide, section on building RPMs]
| |
| * [http://freshrpms.net/docs/fight/ The fight, my first attempt to make a readable rpm package building introduction.]
| |
| * [http://genetikayos.com/code/repos/rpm-tutorial/trunk/rpm-tutorial.html RPM Tutorial (Fullhart)]
| |