~bzr-pqm/bzr/bzr.dev

« back to all changes in this revision

Viewing changes to doc/developers/ppa.txt

  • Committer: John Arbash Meinel
  • Date: 2008-09-09 15:09:12 UTC
  • mto: This revision was merged to the branch mainline in revision 3699.
  • Revision ID: john@arbash-meinel.com-20080909150912-wyttm8he1zsls2ck
Use the right timing function on win32

Show diffs side-by-side

added added

removed removed

Lines of Context:
13
13
 
14
14
  __ https://help.launchpad.net/PPAQuickStart
15
15
 
16
 
As of June 2008, there are three PPAs:
 
16
As of June 2008, there are two PPAs:
17
17
 
18
18
<https://launchpad.net/~bzr/+archive>
19
19
    Final released versions.
21
21
<https://launchpad.net/~bzr-beta-ppa/+archive>
22
22
    Releases and release candidates.    
23
23
 
24
 
<https://launchpad.net/~bzr-nightly-ppa/+archive>
25
 
    Automatic nightly builds from trunk.
26
 
 
27
24
We build packages for every supported Ubuntu release
28
25
<https://wiki.ubuntu.com/Releases>.  Packages need no longer be updated
29
26
when the release passes end-of-life because all users should
37
34
Every package is first uploaded into the beta ppa.  For final release
38
35
versions it is also copied to the main PPA.
39
36
 
40
 
The packaging information is kept in branches of bzr on Launchpad, named
41
 
like 
 
37
The ``debian/`` directory containing the packaging information is kept in
 
38
branches on Launchpad, named like 
42
39
<https://code.launchpad.net/~bzr/bzr/packaging-hardy>.
43
40
or
44
 
<lp:~bzr/bzr/packaging-hardy>.  These branches are intended to be used
45
 
with the ``bzr-builddeb`` plugin.
 
41
<lp:~bzr/bzr/packaging-hardy>.
46
42
 
47
43
Preconditions
48
44
-------------
76
72
    [DEFAULT]
77
73
    default_host_main = notspecified
78
74
  
79
 
* Configure ``bzr-builddeb`` to sign the package, which is required for
80
 
  Launchpad to build it.  Put this in ``~/.bazaar/builddeb.conf`` ::
81
 
 
82
 
      [BUILDDEB]
83
 
      builder = dpkg-buildpackage -rfakeroot
84
 
      source-builder= dpkg-buildpackage -rfakeroot -S -sa
85
 
 
86
75
* You need a Ubuntu (or probably Debian) machine, and ::
87
76
 
88
 
    sudo apt-get install build-essential devscripts dput quilt patch libcrypt-ssleay-perl debhelper cdbs python-docutils
89
 
 
90
 
  Please update this document if you encounter unmet dependencies or find a
91
 
  shorter way to express them.
92
 
 
93
 
* You will also want to have the `bzr-builddeb`_ plugin installed, which
94
 
  depends on `bzrtools`_.
95
 
 
96
 
.. _`bzr-builddeb`: http://launchpad.net/bzr-builddeb
97
 
.. _`bzrtools`: http://launchpad.net/bzrtools
 
77
    sudo apt-get install build-essential devscripts dput quilt patch
 
78
 
 
79
* You will also want to have the ``bzr-builddeb`` plugin installed.
98
80
 
99
81
 
100
82
Packaging Bazaar
107
89
release packages is as simple as::
108
90
 
109
91
  cd ~/dev/bzr/releases/packaging
110
 
  ln ~/dev/bzr/releases/bzr-1.6.tar.gz ./bzr_1.6.orig.tar.gz
111
92
  export UBUNTU_RELEASES="dapper feisty gutsy hardy intrepid"
112
93
  ~/dev/bzr/bzr.dev/tools/packaging/update-packaging-branches.sh
113
94
  ~/dev/bzr/bzr.dev/tools/packaging/update-changelogs.sh 1.6~beta3-1~bazaar1
114
95
  ~/dev/bzr/bzr.dev/tools/packaging/build-packages
115
 
  dput bzr-beta-ppa bzr_1.6~beta3-1~bazaar1*.changes
 
96
  dput bzr-beta-ppa build-area/bzr_1.6~beta3~bazaar1*.changes
116
97
 
117
98
Long Form
118
99
~~~~~~~~~
119
100
 
120
101
#. You will end up checking out a separate directory for each supported
121
 
   release. Such as ``~/dev/bzr/releases/packaging/hardy``. In each of these
122
 
   branches, you will produce the package for the release.
 
102
   release. Such as ``~/dev/bzr/releases/packaging/hardy``
123
103
 
124
104
#. Decide on the final version number.  It should be of this form::
125
105
 
126
106
     bzr-1.6~beta3-1~bazaar1~hardy1
127
107
 
128
 
   **Note:** There are three hyphen-separated parts: the *package name*,
129
 
   the *upstream version*, and the *packaging version*.
 
108
   There are three hyphen-separated parts: the *package name*, the *upstream
 
109
   version*, and the *packaging version*.
130
110
 
131
111
   **Caution:** Upstream betas or release candidates must insert a tilde
132
112
   to make them sort before the final release, like this:
137
117
 
138
118
#. Export the distroreleases that you will be packaging for::
139
119
 
140
 
      export UBUNTU_RELEASES="dapper feisty gutsy hardy intrepid jaunty"
 
120
      export UBUNTU_RELEASES="dapper feisty gutsy hardy intrepid"
141
121
 
142
122
#. Checkout (or update) the packaging branch for each supported release::
143
123
 
148
128
      tools/packaging/update-packaging-branches.sh
149
129
 
150
130
#. The ``bzr-builddeb`` step will download the original tarball if you do
151
 
   not already have it, putting it into a ``tarballs`` directory.
 
131
   not already have it. Putting it into a ``tarballs`` directory.
152
132
 
153
133
#. For Bazaar plugins, change the ``debian/control`` file to express a
154
134
   dependency on the correct version of ``bzr``.
167
147
   against the version number (which is just our convention), so make sure 
168
148
   to specify it.
169
149
 
170
 
   Make sure you have the correct email address for yourself (you may need
171
 
   export DEBEMAIL=`bzr whoami` if it isn't already set), version number, and
172
 
   distribution.  It should look something like this::
 
150
   Make sure you have the correct email address for yourself, version
 
151
   number, and distribution.  It should look something like this::
173
152
 
174
153
       bzr (1.6~beta3-1~bazaar1~hardy1) hardy; urgency=low
175
154
     
200
179
 
201
180
      cd packaging-$DISTRO; bzr builddeb -S
202
181
 
203
 
   This will create a ``.changes`` file.  If you didn't configure builddeb
204
 
   to automatically sign them, you can use ::
205
 
 
206
 
      debsign -m$UID *.changes
207
 
 
208
 
   where ``$UID`` is the gpg key you want to use to sign the changes.
209
 
 
 
182
   This will create a ``.changes`` file in ``build-area``. You will need
 
183
   to sign it with::
 
184
 
 
185
      debsign -m$UID build-area/*.changes
 
186
 
 
187
   Where ``$UID`` is the gpg key you want to use to sign the changes.
 
188
   Alternatively, you can configure ``~/.bazaar/builddeb.conf`` with::
 
189
 
 
190
      [BUILDDEB]
 
191
      builder = dpkg-buildpackage -rfakeroot
 
192
      source-builder= dpkg-buildpackage -rfakeroot -S -sa
 
193
 
 
194
   Which tells ``bzr builddeb`` to automatically sign the package with the
 
195
   key associated with the user who created the changelog entry.
 
196
     
210
197
#. Upload into the beta PPA for each release::
211
198
 
212
 
     dput bzr-beta-ppa bzr_1.6-1*.changes
 
199
     dput bzr-beta-ppa build-area/*.changes
213
200
 
214
201
#. For final release versions, also copy it into the ``~bzr`` PPA::
215
202
 
216
 
     dput bzr-ppa ../bzr_1.6-1\~bazaar1\~hardy1\_source.changes
 
203
     dput bzr-ppa ../bzr__1.6-1\~bazaar1\~hardy1\_source.changes
217
204
 
218
205
   Alternatively, you can use Launchpad's "copy" feature to copy the
219
206
   packages between repositories.
224
211
   <https://launchpad.net/~bzr-beta-ppa/+archive/+builds>.
225
212
 
226
213
 
227
 
Packaging bzr-svn
228
 
~~~~~~~~~~~~~~~~~
229
 
 
230
 
bzr-svn uses a packaging branch that contains both the source 
231
 
(including any changes against upstream) and the ``debian/`` directory.
232
 
 
233
 
To build bzr-svn:
234
 
 
235
 
#. Get a checkout of ``lp:~bzr/bzr-svn/hardy-ppa/``
236
 
 
237
 
#. Merge from ``http://bzr.debian.org/pkg-bazaar/bzr-svn/experimental/``
238
 
  
239
 
   This should bring in both upstream and packaging changes for the new
240
 
   release, and it's updated as part of the bzr-svn release process.
241
 
 
242
 
#. Run ``dch -v 0.4.15-1~bazaar1-hardy1 -D hardy`` or similar
243
 
 
244
 
#. Run ``bzr builddeb --source``
245
 
 
246
 
   bzr-builddeb will automatically check out the appropriate tag from the
247
 
   main branch of bzr-svn, build, and package it.
248
 
 
249
 
#. ``dput bzr-beta-ppa ../bzr-svn_0.4.15-1~bazaar1~hardy1_source.changes``
250
 
 
251
 
 
252
214
Monitoring the contents of PPAs
253
215
-------------------------------
254
216