PackagingGuide:修订间差异
Calvin.ngei(留言 | 贡献) |
Calvin.ngei(留言 | 贡献) |
||
第58行: | 第58行: | ||
大多数包含autoconf工具生成的configure脚本的unix软件源码包都几乎不用其他更深入的工作即可干净地构建。然而有少数源码包里面可能没有configure脚本文件,这需要修改才能工作。由于移植工作固有的缺陷,以及其他不同的平台的软件多种多样[3],我将只涉及将一个可完全正常工作的应用程序源码包在Launchpad打包的问题[4]。 | 大多数包含autoconf工具生成的configure脚本的unix软件源码包都几乎不用其他更深入的工作即可干净地构建。然而有少数源码包里面可能没有configure脚本文件,这需要修改才能工作。由于移植工作固有的缺陷,以及其他不同的平台的软件多种多样[3],我将只涉及将一个可完全正常工作的应用程序源码包在Launchpad打包的问题[4]。 | ||
==5 从可正常工作的源码(Working | ==5 从可正常工作的源码(Working Sources)构建Ubuntu软件包== | ||
我假设读者已经下载了一个应用程序的源代码,并希望将该应用程序构建成一个Debian包。在我的例子中,我写了一个基于脚本的独立应用程序,以及安装、卸载程序,它应该能在大多数Linux发行版上运行[5]。 | 我假设读者已经下载了一个应用程序的源代码,并希望将该应用程序构建成一个Debian包。在我的例子中,我写了一个基于脚本的独立应用程序,以及安装、卸载程序,它应该能在大多数Linux发行版上运行[5]。 | ||
第123行: | 第123行: | ||
Build-Depends: debhelper (>= 5) | Build-Depends: debhelper (>= 5) | ||
Standards-Version: 3.7.2 | Standards-Version: 3.7.2 | ||
Package: vob2mpeg | Package: vob2mpeg | ||
Architecture: any | Architecture: any | ||
第152行: | 第151行: | ||
$ rm debian/*.[Ee][Xx] | $ rm debian/*.[Ee][Xx] | ||
修改规则文件。在我们继续尝试创建Debian的软件包之前,还要修改规则文件。debian/rules文件是一个Makefile文件,make将执行它来编译构建程序。在这里,由于我们什么也不编译,这个文件将被削减到仅仅只包含创建一个软件分发所需要的内容。这个应用程序(vob2mpeg)有一个安装(和卸载)脚本必须被执行。例如,vob2mpeg通过执行一个包含可选的配置文件并可指定安装位置的安装脚本,这样安装在Linux系统里面。由于我们希望所有的文件安装到./debian/vob2mpeg,我们从上游源文件提供的例子文件来创建一个配置文件。 | |||
$ cp vob2mpeg-install.conf debian/ | $ cp vob2mpeg-install.conf debian/ | ||
第167行: | 第166行: | ||
export DEST_BIN=/tmp/test/usr/bin | export DEST_BIN=/tmp/test/usr/bin | ||
export DEST_DOC=/tmp/test/usr/share/doc/vob2mpeg | export DEST_DOC=/tmp/test/usr/share/doc/vob2mpeg | ||
# The files to actually install, please do not change this | # The files to actually install, please do not change this | ||
export ETC_FILES="vob2mpeg.profile $CONF_FILE" | export ETC_FILES="vob2mpeg.profile $CONF_FILE" | ||
第186行: | 第184行: | ||
export DEST_BIN=debian/vob2mpeg/usr/bin | export DEST_BIN=debian/vob2mpeg/usr/bin | ||
export DEST_DOC=debian/vob2mpeg/usr/share/doc/vob2mpeg | export DEST_DOC=debian/vob2mpeg/usr/share/doc/vob2mpeg | ||
# The files to actually install, please do not change this | # The files to actually install, please do not change this | ||
export ETC_FILES="vob2mpeg.profile $CONF_FILE" | export ETC_FILES="vob2mpeg.profile $CONF_FILE" | ||
第194行: | 第191行: | ||
$ | $ | ||
因此,我们确保当运行vob2mpeg安装脚本时,它会自行安装到./debian/vob2mpeg。然后,我们可以从该目录中的文件创建deb包。现在我们修改规则文件来告诉它如何建立包文件(会被安装的文件)。因为我们将只修改构建(build)、安装(install)和清理(clean)的目标,我将把该文件的其余部分<...喀嚓...>掉。 | |||
$ cat debian/rules | $ cat debian/rules | ||
#!/usr/bin/make -f | #!/usr/bin/make -f | ||
<... | <...喀嚓...> | ||
build-stamp: configure-stamp | build-stamp: configure-stamp | ||
dh_testdir | dh_testdir | ||
# Add here commands to compile the package. | # Add here commands to compile the package. | ||
$(MAKE) | $(MAKE) | ||
#docbook-to-man debian/vob2mpeg.sgml > vob2mpeg.1 | #docbook-to-man debian/vob2mpeg.sgml > vob2mpeg.1 | ||
touch $@ | touch $@ | ||
clean: | clean: | ||
dh_testdir | dh_testdir | ||
dh_testroot | dh_testroot | ||
rm -f build-stamp configure-stamp | rm -f build-stamp configure-stamp | ||
# Add here commands to clean up after the build process. | # Add here commands to clean up after the build process. | ||
-$(MAKE) clean | -$(MAKE) clean | ||
dh_clean | dh_clean | ||
install: build | install: build | ||
dh_testdir | dh_testdir | ||
第223行: | 第214行: | ||
dh_clean -k | dh_clean -k | ||
dh_installdirs | dh_installdirs | ||
# Add here commands to install the package into debian/vob2mpeg. | # Add here commands to install the package into debian/vob2mpeg. | ||
$(MAKE) DESTDIR=$(CURDIR)/debian/vob2mpeg install | $(MAKE) DESTDIR=$(CURDIR)/debian/vob2mpeg install | ||
<... | <...喀嚓...> | ||
$ vi debian/rules | $ vi debian/rules | ||
$ cat debian/rules | $ cat debian/rules | ||
#!/usr/bin/make -f | #!/usr/bin/make -f | ||
<... | <...喀嚓...> | ||
build-stamp: configure-stamp | build-stamp: configure-stamp | ||
dh_testdir | dh_testdir | ||
# Add here commands to compile the package. | # Add here commands to compile the package. | ||
#docbook-to-man debian/vob2mpeg.sgml > vob2mpeg.1 | #docbook-to-man debian/vob2mpeg.sgml > vob2mpeg.1 | ||
touch $@ | touch $@ | ||
clean: | clean: | ||
dh_testdir | dh_testdir | ||
dh_testroot | dh_testroot | ||
rm -f build-stamp configure-stamp | rm -f build-stamp configure-stamp | ||
# Add here commands to clean up after the build process. | # Add here commands to clean up after the build process. | ||
rm -rf ./debian/vob2mpeg | rm -rf ./debian/vob2mpeg | ||
dh_clean | dh_clean | ||
install: build | install: build | ||
dh_testdir | dh_testdir | ||
第255行: | 第238行: | ||
dh_clean -k | dh_clean -k | ||
dh_installdirs | dh_installdirs | ||
# Add here commands to install the package into debian/vob2mpeg. | # Add here commands to install the package into debian/vob2mpeg. | ||
./install-vob2mpeg.sh ./debian/vob2mpeg-install.conf | ./install-vob2mpeg.sh ./debian/vob2mpeg-install.conf | ||
<... | <...喀嚓...> | ||
$ | $ | ||
2010年10月26日 (二) 06:19的版本
文章出处: |
{{#if: | {{{2}}} | http://ubuntusci.meraka.org.za/wiki/Documentation/PackagingGuide }} |
Debian打包入門
Lelanthran K. Manickum
2009年1月13日
1 前言
在Ubuntusci [1]的一部分努力之下,许多没有被Ubuntu软件仓库收录的软件包被添加到了仓库中。把其他类UNIX系统上的软件(或者其他Linux发行版上的软件)移植到Ubuntu Linux中是一件复杂的事情,需要的时间和努力会比预期更多。
不考虑Ubuntu软件仓库,任何已经出现在Debian软件仓库中至少4至5年的软件都将可能成为我们移植打包工作可能面临的困难。这还是个保守的假设。如果仅仅只是将源代码拷贝过来,简单地为Ubuntu(或者Debian)编译一下就可以,相信很多人早就做过了。那些特定的、一直以来没有人移植打包的软件主要是因为他们在Debian/Ubuntu上不能完美编译。
这份文档针对那些从未试过给Debian/Ubuntu制作软件包的读者。因为我们发现,即使软件编译和运行无错,打包的实际过程仍然可能会让人感到困惑。希望随着项目的推进,社区把更多的精力花费在软件包检查上,使我们制作的软件包质量过硬。
2 工具
Ubuntu/Debian的开发新手经常会对“source”这个词感到困惑。“Source-code”通常指某个程序(program),或者某个应用(application),或者软件包的源代码。当我们说“Sources”的时候,指的是用于构建软件包的文件。例如,软件包“Foo”的“source-code”(源代码)是一个或者一堆文本文件,通过GCC编译连接之后可以产生二进制可执行文件;而我们所说的“Foo”软件包的“sources”,指的是所有用于构建Foo.deb这个debian包的文件,其中包括源代码文件。
构建deb软件包的基本过程如下:
* 下载软件的源码包; * 把源码包解压缩到某个目录; * 在源码目录内创建debian化目录 (./debian). * 修改./debian目录内的文件,如包维护者的详细信息、包描述,等等; * 在本机编译源代码; * 在本机生成.deb包; * 把经过我们修改后能成功编译生成deb包的sources上传到Launchpad PPA[1]。
当软件成功地上传到Launchpad,并在Launchpad上成功编译生成deb包后,我们的工作就基本上完成了。我们的Launchpad PPA源地址可以分享给其他想使用我们的deb包的人。我们甚至可以申请把我们的deb包移入Ubuntu的官方主软件仓库中。
这过程中需要用到的工具至少有:
* 浏览器,或者类似的软件——用于下载软件的源代码包; * 解压缩软件——用于解压下载回来的源代码包; * dh_make(dh-make包的一部分)——用于自动创建./debian目录和其他用于创建.deb包的骨架模板文件; * make(Gnu make)——构建过程中要用到的工具; * debchange/dch(devscripts包的一部分)——用于编辑包的版本号; * debuild(devscripts包的一部分)——运行构建过程,包括编译连接,以及生成deb包; * fakeroot(fakeroot包的一部分)——这个东西是必须的; * dput——上传经过签名的deb文件。
建议所有打包工作都在较新的Ubuntu系统下进行,这样可以大大方便和简化整个过程。
3 引入异种包(Alien Packages)
异种包(Alien Packages)是针对其他系统的软件包。例如针对Red Hat系统的软件包,是RPM格式的。比起那些还未打包过的软件来,将这些软件移植到Ubuntu系统相对比较容易,因为所有的包依赖、运行时依赖、编译时依赖等,都是已知的。
软件包alien(软件仓库中有)能够自动地将其他二进制异种包转换成.deb包。不过,这种转换仅仅只限于二进制包。理想的deb包构应该从源代码开始,所有用于构建deb包的源文件(sources)都应该是源代码(source-code)。
4 编译专门针对类Unix系统的源码包
下载源代码后,将其解压到一个目录中,给该源代码目录起个适合的名字,例如“Foo-1.2.3”[2]。
在终端中,cd进刚才所说的那个源代码目录,执行dh_make,生成打包需要用到的文件,包括一些控制文件(control files)和编译规则文件(rules文件,自动生成的rules文件使用了默认规则)。
大多数包含autoconf工具生成的configure脚本的unix软件源码包都几乎不用其他更深入的工作即可干净地构建。然而有少数源码包里面可能没有configure脚本文件,这需要修改才能工作。由于移植工作固有的缺陷,以及其他不同的平台的软件多种多样[3],我将只涉及将一个可完全正常工作的应用程序源码包在Launchpad打包的问题[4]。
5 从可正常工作的源码(Working Sources)构建Ubuntu软件包
我假设读者已经下载了一个应用程序的源代码,并希望将该应用程序构建成一个Debian包。在我的例子中,我写了一个基于脚本的独立应用程序,以及安装、卸载程序,它应该能在大多数Linux发行版上运行[5]。
下载源码包。我们可以从sourceforge下载下面例子中用到的vob2mpeg版本。用下面的命令取得所使用的应用程序的确切版本。
$ svn co https://vob2mpeg.svn.sourceforge.net/svnroot/vob2mpeg/tags/vob2mpeg-0.0.1 A vob2mpeg-0.0.1/vob2mpeg.profile A vob2mpeg-0.0.1/uninstall-vob2mpeg.sh A vob2mpeg-0.0.1/vob2mpeg A vob2mpeg-0.0.1/LICENCE A vob2mpeg-0.0.1/VERSION A vob2mpeg-0.0.1/CHANGELOG A vob2mpeg-0.0.1/vob2mpeg-install.conf A vob2mpeg-0.0.1/CREDITS A vob2mpeg-0.0.1/README A vob2mpeg-0.0.1/install-vob2mpeg.sh Checked out revision 7.
此时不需要解压,因为我们取回的上游源代码是未压缩的。同样,源码目录页无需重新命名,它已经是适合的名字了:vob2mpeg-0.0.1。我们需要做的是,创建一个原始上游源代码的压缩包,以便我们对程序源代码所做的任何修改都能记录下来并跟未作修改的原始上游源代码作比较。
创建Debian控制文件。令人高兴的是,dh_make能用--create-orig标志创建原始上游压缩缩包。同时dh_make还生成所有其他用于构建deb包所需的所有控制文件:
$ cd vob2mpeg-0.0.1/ $ ls -F CHANGELOG README vob2mpeg-install.conf CREDITS uninstall-vob2mpeg.sh* vob2mpeg.profile install-vob2mpeg.sh* VERSION LICENCE vob2mpeg* $ dh_make --createorig --copyright GPL --email [email protected] --single Maintainer name : Lelanthran Krishna Manickum Email-Address : [email protected] Date : Mon, 12 Jan 2009 22:42:04 +0200 Package Name : vob2mpeg Version : 0.0.1 License : gpl Type of Package : Single Hit <enter> to confirm: Currently there is no top level Makefile. This may require additional tuning. Done. Please edit the files in the debian/ subdirectory now. You should also check that the vob2mpeg Makefiles install into $DESTDIR and not in / . $ ls -F CHANGELOG install-vob2mpeg.sh* uninstall-vob2mpeg.sh* vob2mpeg-install.conf CREDITS LICENCE VERSION vob2mpeg.profile debian/ README vob2mpeg* $ ls -F debian/ changelog emacsen-install.ex manpage.xml.ex rules* compat emacsen-remove.ex menu.ex vob2mpeg-default.ex control emacsen-startup.ex postinst.ex vob2mpeg.doc-base.EX copyright init.d.ex postrm.ex watch.ex cron.d.ex init.d.lsb.ex preinst.ex dirs manpage.1.ex prerm.ex docs manpage.sgml.ex README.Debian
可以看到,“debian”目录已经生成。这个目录里面包含所有Debian建包工具创建deb包所需的信息,包括用于编译应用程序自身的构建指令。这些指令是一种解释程序,无需编译任何实际的源代码。
修改控制文件。在我们继续深入之前,debian目录下的文件要作一些修改。首先,必须编辑控制文件,使之反映正确的信息。这样的编辑,结果如下:
$ cat debian/control Source: vob2mpeg Section: unknown Priority: extra Maintainer: Lelanthran Krishna Manickum <[email protected]> Build-Depends: debhelper (>= 5) Standards-Version: 3.7.2 Package: vob2mpeg Architecture: any Depends: ${shlibs:Depends}, ${misc:Depends} Description: <insert up to 60 chars description> <insert long description, indented with spaces> $ vi debian/control $ cat debian/control Source: vob2mpeg Section: graphics Priority: extra Maintainer: Lelanthran Krishna Manickum <[email protected]> Build-Depends: debhelper (>= 5) Standards-Version: 3.7.2 Package: vob2mpeg Architecture: any Depends: ffmpeg, tcl, tk Homepage: http://vob2mpeg.sourceforge.net/ Description: GUI app to convert VOB files to MPEG files A GUI wrapper to convert VOB files to MPEG files using ffmpeg. Allows user to change certain attributes of the movies in the conversion, such as scale, colour (hue, etc), etc. Can be also totally controlled from the command line enabling batch use. $
最后,在这个简单的打包练习例子中,所有debian目录下的的样板文件(*.[Ee][Xx])都是非必须的——这些文件只不过是例子罢了,故此我们将其删除。
$ rm debian/*.[Ee][Xx]
修改规则文件。在我们继续尝试创建Debian的软件包之前,还要修改规则文件。debian/rules文件是一个Makefile文件,make将执行它来编译构建程序。在这里,由于我们什么也不编译,这个文件将被削减到仅仅只包含创建一个软件分发所需要的内容。这个应用程序(vob2mpeg)有一个安装(和卸载)脚本必须被执行。例如,vob2mpeg通过执行一个包含可选的配置文件并可指定安装位置的安装脚本,这样安装在Linux系统里面。由于我们希望所有的文件安装到./debian/vob2mpeg,我们从上游源文件提供的例子文件来创建一个配置文件。
$ cp vob2mpeg-install.conf debian/ $ cat debian/vob2mpeg-install.conf # # Installation settings for vob2mpeg installation script # Store variables in this file so that porting to different # packaging systems becomes trivial and not hellish # # Variables in this file are never over-ridden, uncomment # the lines below and replace with your own settings # export DEST_ETC=/tmp/test/etc export DEST_BIN=/tmp/test/usr/bin export DEST_DOC=/tmp/test/usr/share/doc/vob2mpeg # The files to actually install, please do not change this export ETC_FILES="vob2mpeg.profile $CONF_FILE" export DOC_FILES="README CREDITS LICENCE VERSION CHANGELOG" export BIN_FILES="vob2mpeg install-vob2mpeg.sh uninstall-vob2mpeg.sh" # $ vi debian/vob2mpeg-install.conf $ cat debian/vob2mpeg-install.conf # # Installation settings for vob2mpeg installation script # Store variables in this file so that porting to different # packaging systems becomes trivial and not hellish # # Variables in this file are never over-ridden, uncomment # the lines below and replace with your own settings # export DEST_ETC=debian/vob2mpeg/etc export DEST_BIN=debian/vob2mpeg/usr/bin export DEST_DOC=debian/vob2mpeg/usr/share/doc/vob2mpeg # The files to actually install, please do not change this export ETC_FILES="vob2mpeg.profile $CONF_FILE" export DOC_FILES="README CREDITS LICENCE VERSION CHANGELOG" export BIN_FILES="vob2mpeg install-vob2mpeg.sh uninstall-vob2mpeg.sh" # $
因此,我们确保当运行vob2mpeg安装脚本时,它会自行安装到./debian/vob2mpeg。然后,我们可以从该目录中的文件创建deb包。现在我们修改规则文件来告诉它如何建立包文件(会被安装的文件)。因为我们将只修改构建(build)、安装(install)和清理(clean)的目标,我将把该文件的其余部分<...喀嚓...>掉。
$ cat debian/rules #!/usr/bin/make -f <...喀嚓...> build-stamp: configure-stamp dh_testdir # Add here commands to compile the package. $(MAKE) #docbook-to-man debian/vob2mpeg.sgml > vob2mpeg.1 touch $@ clean: dh_testdir dh_testroot rm -f build-stamp configure-stamp # Add here commands to clean up after the build process. -$(MAKE) clean dh_clean install: build dh_testdir dh_testroot dh_clean -k dh_installdirs # Add here commands to install the package into debian/vob2mpeg. $(MAKE) DESTDIR=$(CURDIR)/debian/vob2mpeg install <...喀嚓...> $ vi debian/rules $ cat debian/rules #!/usr/bin/make -f <...喀嚓...> build-stamp: configure-stamp dh_testdir # Add here commands to compile the package. #docbook-to-man debian/vob2mpeg.sgml > vob2mpeg.1 touch $@ clean: dh_testdir dh_testroot rm -f build-stamp configure-stamp # Add here commands to clean up after the build process. rm -rf ./debian/vob2mpeg dh_clean install: build dh_testdir dh_testroot dh_clean -k dh_installdirs # Add here commands to install the package into debian/vob2mpeg. ./install-vob2mpeg.sh ./debian/vob2mpeg-install.conf <...喀嚓...> $
The only lines that have been changed are those that execute the compilation, the installation of the files and the removal of all the files, so the targets build, install and clean have been modified so that compile does nothing (there is nothing to compile), the target install merely calls the installation program to install the files to the debian/vob2mpeg directory and the clean target only removes that same directory.
Note that we have neglected to provide the preinst and postinst scripts in the debian/ directory. These scripts, if present, are respectively run prior to installation of the package and after the removal of the package. This particular application has no need to run any commands before installation nor any commands after removal.
Package Creation. Now that we are done with all the changes we wish to make, we can issue the commands required to create the .deb file. Before we do so, however, we need to ensure that the correct Debian package version number is reflected in the newly created package. This should not be confused with the applications version number, which is the version number of the application. The package version number is the version of our package. For example, it is possible that for application Foo we decide to package version 1 of the applica- tion. In other words, the directory we use is Foo-1.0.0. After packaging Foo, we assign that package the version number 0.0.1.
Now let’s assume that there was an error in the packaging, for example, perhaps we compiled Foo using a flag that caused it to break on lpia architectures. A user submits a report and we quickly fix the problem. This results in the package having the new version of 0.0.2 while the application itself is still Foo-1.0.0.
Updating the Version Number. To automatically manage the version numbers of the package, we use a tool called dch. A plain invocation of dch without any command-line arguments results in an increment of the minor ver- sion number, while invoking it as dch -i results in the package recieving an increment to the major version number.
Upon running dch for the first time, we are presented with an editor[6] that should display something similar to the following:
vob2mpeg (0.0.1-1) unstable; urgency=low
* Initial release (Closes: #nnnn) <nnnn is the bug number of your ITP> *
-- Lelanthran Krishna Manickum <lmanickum@esprit> Mon, 12 Jan 2009 23:39:19 +0200
We edit the above file so that unstable is replaced with the actual Debian distribution name (in this example I use Intrepid, as that is what was used in the production of this document and the package). Each comment should also follow the given convention, starting with an asterisk and indented to the previous line. The changed file looks like this:
vob2mpeg (0.0.1-1) intrepid; urgency=low
* Initial release * Edited rules and removed build instructions * Edited rules and replaced command for installation * Edited rules and replaced command for target ’clean’
-- Lelanthran Krishna Manickum <lmanickum@esprit> Mon, 12 Jan 2009 23:39:19 +0200
Now we can go ahead and create the actual .deb archive by running the debian/rules script, like this:
$ fakeroot debian/rules binary-arch dh_testdir dh_testroot dh_clean -k dh_installdirs # Add here commands to install the package into debian/vob2mpeg. ./install-vob2mpeg.sh ./debian/vob2mpeg-install.conf Found installation configuration in ./debian/vob2mpeg-install.conf -----------./debian/vob2mpeg-install.conf-------------- DEST_ETC is already set to debian/vob2mpeg/etc DEST_BIN is already set to debian/vob2mpeg/usr/bin DEST_DOC is already set to debian/vob2mpeg/usr/share/doc/vob2mpeg ETC_FILES is already set to vob2mpeg.profile ./debian/vob2mpeg-install.conf DOC_FILES is already set to README CREDITS LICENCE VERSION CHANGELOG BIN_FILES is already set to vob2mpeg install-vob2mpeg.sh uninstall-vob2mpeg.sh install: creating directory ‘debian/vob2mpeg/etc’ install: creating directory ‘debian/vob2mpeg/usr/share’ install: creating directory ‘debian/vob2mpeg/usr/share/doc’ install: creating directory ‘debian/vob2mpeg/usr/share/doc/vob2mpeg’ ‘vob2mpeg.profile’ -> ‘debian/vob2mpeg/etc/vob2mpeg.profile’ ‘./debian/vob2mpeg-install.conf’ -> ‘debian/vob2mpeg/etc/vob2mpeg-install.conf’ ‘README’ -> ‘debian/vob2mpeg/usr/share/doc/vob2mpeg/README’ ‘CREDITS’ -> ‘debian/vob2mpeg/usr/share/doc/vob2mpeg/CREDITS’ ‘LICENCE’ -> ‘debian/vob2mpeg/usr/share/doc/vob2mpeg/LICENCE’ ‘VERSION’ -> ‘debian/vob2mpeg/usr/share/doc/vob2mpeg/VERSION’ ‘CHANGELOG’ -> ‘debian/vob2mpeg/usr/share/doc/vob2mpeg/CHANGELOG’ ‘vob2mpeg’ -> ‘debian/vob2mpeg/usr/bin/vob2mpeg’ ‘install-vob2mpeg.sh’ -> ‘debian/vob2mpeg/usr/bin/install-vob2mpeg.sh’ ‘uninstall-vob2mpeg.sh’ -> ‘debian/vob2mpeg/usr/bin/uninstall-vob2mpeg.sh’ dh_testdir dh_testroot dh_installchangelogs CHANGELOG dh_installdocs dh_installexamples dh_installman dh_link dh_strip dh_compress dh_fixperms dh_installdeb dh_shlibdeps dh_gencontrol dpkg-gencontrol: warning: unknown substitution variable ${shlibs:Depends} dpkg-gencontrol: warning: unknown substitution variable ${misc:Depends} dh_md5sums dh_builddeb dpkg-deb: building package ‘vob2mpeg’ in ‘../vob2mpeg_0.0.1-1_i386.deb’. $
This creates the debian/vob2mpeg directory tree, and uses that tree, along with the control files, to create the ../vob2mpeg_0.0.1-1_i386.deb file. At this point, we can stop if we only want to create packages for our own use. However, if we need to distribute our packages (such as through Launchpad), then we need to ensure that our package is signed by our Launchpad key.
6 上傳並發佈軟件包
Launchpad provides a very convenient way to redistribute our packages. We simply upload the upstream sources, upload the changes we made to the upstream sources and let Launchpad then build the packages for us. This ensures that, not only do we build our packages on our local machine, but we also find out if the package builds on the various Launchpad virtual machines.
The very first thing to do, if we haven’t already done so, is to create a Launchpad account for us to use. This account will give us a PPA, or Personal Package Archive. All the packages we upload will go into our PPA, and the URL for our PPA can be added to any sources.list file so that our package can be installed via the normal apt-get or synaptic methods by the user.
All the steps in creating an account on Launchpad is beyond the scope of this report, but full instructions and comprehensive help is available on Launchpad itself - https://launchpad.net/. Part of the creation of the Launchpad account requires the user to generate a cryptography key and use this key to digitally sign the code of conduct. This very same will will be used to generate a digitally signed package.
Signing. Once we have tested that our rules file works, we are ready to send the upstream sources and our changes to Launchpad. The program debuild generates a set of files suitable for Launchpad. We specify the key to use when digitally signing the package.
$ debuild -S -kFB43CE54 dpkg-buildpackage -rfakeroot -d -us -uc -S dpkg-buildpackage: set CFLAGS to default value: -g -O2 dpkg-buildpackage: set CPPFLAGS to default value: dpkg-buildpackage: set LDFLAGS to default value: -Wl,-Bsymbolic-functions dpkg-buildpackage: set FFLAGS to default value: -g -O2 dpkg-buildpackage: set CXXFLAGS to default value: -g -O2 dpkg-buildpackage: source package vob2mpeg dpkg-buildpackage: source version 0.0.1-1 dpkg-buildpackage: source changed by Lelanthran Krishna Manickum <lmanickum@esprit> fakeroot debian/rules clean dh_testdir dh_testroot rm -f build-stamp configure-stamp # Add here commands to clean up after the build process. rm -rf ./debian/vob2mpeg dh_clean dpkg-source -b vob2mpeg-0.0.1 dpkg-source: info: using source format ‘1.0’ dpkg-source: info: building vob2mpeg using existing vob2mpeg_0.0.1.orig.tar.gz dpkg-source: info: building vob2mpeg in vob2mpeg_0.0.1-1.diff.gz dpkg-source: info: building vob2mpeg in vob2mpeg_0.0.1-1.dsc dpkg-genchanges -S >../vob2mpeg_0.0.1-1_source.changes dpkg-genchanges: including full source code in upload dpkg-buildpackage: source only upload (original source is included) Now running lintian... E: vob2mpeg_0.0.1-1_source.changes: bad-distribution-in-changes-file intrepid W: vob2mpeg source: out-of-date-standards-version 3.7.2 (current is 3.8.0) W: vob2mpeg source: changelog-should-mention-nmu W: vob2mpeg source: source-nmu-has-incorrect-version-number 0.0.1-1 Finished running lintian. Now signing changes and any dsc files... signfile vob2mpeg_0.0.1-1.dsc FB43CE54
You need a passphrase to unlock the secret key for user: "Lelanthran Krishna Manickum (Final) <[email protected]>" 1024-bit DSA key, ID FB43CE54, created 2008-10-15
signfile vob2mpeg_0.0.1-1_source.changes FB43CE54
You need a passphrase to unlock the secret key for user: "Lelanthran Krishna Manickum (Final) <[email protected]>" 1024-bit DSA key, ID FB43CE54, created 2008-10-15
Successfully signed dsc and changes files $ ls -F .. vob2mpeg-0.0.1/ vob2mpeg_0.0.1-1_source.build vob2mpeg_0.0.1-1.diff.gz vob2mpeg_0.0.1-1_source.changes vob2mpeg_0.0.1-1.dsc vob2mpeg_0.0.1.orig.tar.gz vob2mpeg_0.0.1-1_i386.deb $
Uploading. Now that we have a set of files that are signed with our key, all thats left is to upload those files to Launchpad. A program called dput is used. In order to use it, we need a ~/.dput.cf that specifies the Launchpad account to beused. My ~/.dput.cf file looks like this:
$ cat ~/.dput.cf [my-ppa] fqdn = ppa.launchpad.net method = ftp incoming = ~lmanickum/ubuntu/ login = anonymous allow_unsigned_uploads = 0
When using dput to upload files to my lmanickum account on Launchpad I will tell dput to use the profile my-ppa, like this:
$ cd .. $ dput my-ppa vob2mpeg_0.0.1-1_source.changes Checking Signature on .changes gpg: Signature made Tue 13 Jan 2009 08:13:33 SAST using DSA key ID FB43CE54 gpg: Good signature from "Lelanthran Krishna Manickum (Final) <[email protected]>" Good signature on /home/lelanthran/pack/vob2mpeg_0.0.1-1_source.changes. Checking Signature on .dsc gpg: Signature made Tue 13 Jan 2009 08:13:23 SAST using DSA key ID FB43CE54 gpg: Good signature from "Lelanthran Krishna Manickum (Final) <[email protected]>" Good signature on /home/lelanthran/pack/vob2mpeg_0.0.1-1.dsc. Uploading to my-ppa (via ftp to ppa.launchpad.net): vob2mpeg_0.0.1-1.dsc: done. vob2mpeg_0.0.1.orig.tar.gz: done. vob2mpeg_0.0.1-1.diff.gz: done. vob2mpeg_0.0.1-1_source.changes: done. Successfully uploaded packages. Not running dinstall. $
PPA. If a problem exists, then Launchpad will notify us via email. Once Launchpad has unarchived our upstream sources, applied our changes, run the build and install targets[7] and created the .deb file, then we should see the package listed in ourPPA, as shown in Figure 1. If there are problems, then they will also be listed there, and clicking on the relevant text will take you to the build log, which will help you identify the problem.