| Packaging guidelines for GStreamer |
| ---------------------------------- |
| |
| Here are some guidelines for people trying to package GStreamer. |
| |
| VERSIONS |
| -------- |
| |
| First of all, there are two concepts of version in GStreamer. |
| The first is the source package version; it is either of the form |
| x.y.z or x.y.z.n |
| |
| x is the major number, y is the minor number, z is the micro number, and |
| n (if it exists) is the nano number. |
| |
| In the first case, it is an official release of GStreamer. |
| In the second case, it is a cvs version tarball if n == 1, and a prerelease |
| for the next version if n > 1. |
| |
| Source releases where y is even are considered "stable", and source releases |
| where y is uneven are considered "unstable" or "development". This is similar |
| to a lot of projects, including GLib and the kernel. |
| |
| The second version is an "interface" version, used in versioning tools, the |
| library name, packages, GConf install paths, registry locations, and so on. |
| It is of the form x.y |
| Commonly, it is refered to as the "major/minor" number of GStreamer. |
| In most cases it is the same as the one used in the source version; only |
| when we are doing release candidates for a new major/minor source version do |
| we manually force the major/minor to be the same as the one for the next |
| new version. This is done to shake out bugs that can arise due to this change |
| before we do an actual x.y.0 release. |
| |
| PARALLEL INSTALLABILITY |
| ----------------------- |
| Versions of GStreamer with a different "interface" or major/minor version are |
| supposed to be parallel-installable. If they're not then it's considered to |
| be a bug. |
| |
| There are parallel-installable versions from the 0.6 set and onwards. |
| |
| In practice, this means that |
| - libraries contain the major/minor version in their name |
| - plugins are installed in a major/minor-versioned directory |
| - include headers are installed in separate directories |
| - registry is saved in major/minor-versioned locations |
| - major/minor-versioned tools are installed, together with versioned man pages |
| - non-versioned front-end tools are also installed, that call the |
| versioned ones, and only depend on glib and popt. |
| |
| So, all parts of GStreamer are parallel-installable, EXCEPT for the |
| non-versioned tools and man pages. However, only one of these sets needs |
| to be present, and preferably the latest source version of them. |
| |
| PACKAGING |
| --------- |
| To make packages of different major/minor versions parallel installable, the |
| important part is to separate the package of the nonversioned tools and |
| man pages, and make them usable for all the GStreamer library packages. |
| |
| We recommend putting the versioned binaries and man pages in the same package |
| as the base GStreamer library. |
| |
| The base GStreamer library should require a version of the non-versioned tools, |
| so that users can expect the non-versioned tools to be present in all cases, |
| and our documentation agrees with the install. |
| |
| As for package names, we recommend the following system: |
| |
| - "gstreamer" as the base name should be used for the latest stable version |
| of GStreamer. |
| - "gstreamerxy" should be used for all other versions (older stable version, |
| as well as current development version) |
| |
| As an example: |
| - 0.7 is current development version, and 0.6 is latest stable version: |
| "gstreamer" for 0.6 and "gstreamer07" for 0.7 |
| - 0.8.0 gets released: |
| "gstreamer06" for 0.6, "gstreamer07" is kept for 0.7, and |
| "gstreamer" for 0.8, where: |
| - the 0.8 "gstreamer" package can now obsolete the 0.7 package |
| - the 0.6 "gstreamer06" package can obsolete previous "gstreamer" packages |
| with lower version/release |
| |
| This ensures that users who just want the latest stable version of GStreamer |
| can just install the "gstreamer"-named set of packages, while automatic |
| tools can still upgrade cleanly, maintaining compatibility for applications |
| requiring older versions. |
| |
| This base named should be used for all GStreamer packages; |
| for example gstreamer07-plugins is a package of plugins to work with |
| the gstreamer07 base library package. |
| |
| SPLITTING OF PLUGIN PACKAGES |
| ---------------------------- |
| Since GStreamer can depend on, but isn't forced to depend on, more than |
| 40 additional libraries, choosing how to package these is a challenge |
| compared to other projects. |
| |
| Three approaches have been used in the past. One was "one package per |
| dependency library", so that users could choose exactly what functionality |
| they want installed. |
| A second one was "split according to functionality". This is more arbitrary. |
| A third one, used by some distributors, is "put everything we want to ship |
| in one big package". |
| |
| Packagers seem to agree that the first approach is too hard and users do not |
| care this much about fine-grained control. |
| We decided on a mix of 2) and 3); preferring to follow the base distribution's |
| decision for the base -plugins package, then creating additional packages |
| based on functionality. |
| |
| Plugins are put in -audio, -video, -dvd and -alsa packages. Also, some |
| plugins are put in -extras- packages because they are distributed from a |
| different location, are not as well maintained, have other issues, ... |
| |
| In the case of Fedora, for example, mp3 plugins are shipped in -extras-audio, |
| and distributed on FreshRPMS or rpm.livna.org |
| For Mandrake, for example, they would be shipped from PLF. |
| |
| Now, to make sure other packages can require functionality they need, |
| virtual provides are added for plugin packages, combining the base gstreamer |
| name with the name of the actual GStreamer plugin. |
| |
| Assuming 0.7, and the mad plugin, the package "gstreamer07-plugins-extra-audio" |
| would virtual-provide "gstreamer07-mad". It would contain the file |
| libgstmad.so in the correct directory. |
| |
| PACKAGING TIPS FOR RPMS |
| ----------------------- |
| * use a define for the base package name for all GStreamer spec files: |
| %define gstreamer gstreamer07 |
| * use a define for the major/minor version of the package: |
| %define majorminor 0.7 |
| |
| This ensures you can easily migrate your spec files when a new major/minor |
| version is released. |
| |
| * always use the correctly versioned gst-register-x.y tool in post scripts |
| that install plugins. |
| It helps to create a define for this as well: |
| %define register %{_bindir}/gst-register-%{majorminor} > /dev/null 2>&1 |
| |
| * make each package that installs plugins have (pre) and (post) requires |
| on the versioned register binary |
| |
| * make each package that installs plugins have a requires on the corresponding |
| base plugins package |
| |
| * make sure that the nonversioned tools and man pages are put in a package |
| that is named "gstreamer-tools" no matter what the major/minor version is. |
| This way, the latest version of this package can be used for all previous |
| major/minor packages. If you do not want this package twice, with different |
| versions, then write your spec so that you don't package the tools for |
| previous versions, and only for the latest version. |
| |
| * applications that require specific plugins to function should require |
| the correct -plugins package, as well as any additional virtual provides |
| they need to pull in. |
| |
| * stable releases can obsolete: the previous development releases to ensure |
| they get removed when installing the new stable version. |