File: RELEASING

package info (click to toggle)
libqrtr-glib 1.4.0-1
  • links: PTS, VCS
  • area: main
  • in suites: forky, sid
  • size: 288 kB
  • sloc: ansic: 1,493; sh: 19; makefile: 6; javascript: 5
file content (67 lines) | stat: -rw-r--r-- 2,464 bytes parent folder | download
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67

The libqrtr releases are generated using meson.

1) For major releases:
    * Increment minor meson 'version' component (eg 1.x.y -> 1.x+1.0).
    * Assuming API/ABI compatibility, increment both qrtr_glib_lt_current and
      qrtr_glib_lt_age.

2) For stable branch releases:
    * Increment micro meson 'version' component (eg 1.x.y -> 1.x.y+1).

3) Configure and build the whole project, making sure gtk-doc and introspection
   are enabled:
    $ meson setup build \
        --prefix=/usr \
        --buildtype=release \
        -Dintrospection=true \
        -Dgtk_doc=true
    $ ninja -C build

4) Run the test suite and install locally:
    $ ninja -C build test
    $ sudo ninja -C build install

5) Push changes to a release MR on gitlab
    * Use a commit title like "release: bump version to 1.4.0"
    * Once CI passes merge the PR.

6) Add and push a signed tag:
    $ git tag -s 1.2.0
      (use a description like "Release 1.2.0")
    $ git push tag 1.2.0

7) Create directories for the gtk-doc documentation in freedesktop.org, and also
   update the 'latest' links:
    $ ssh fd.o
    [fd.o] $ cd ${libqmi}/libqrtr-glib/
    [fd.o] $ rm latest
    [fd.o] $ mkdir -p ${VERSION}
    [fd.o] $ ln -s ${VERSION} latest

8) Copy documentation from /usr/share/gtk-doc and fix online references manually
    $ mkdir html
    $ cp -r /usr/share/gtk-doc/html/libqrtr-glib/* html/
    $ for FILE in $(ls html/*.html); do \
        sed -i 's|<a[^>]* href="\.\./glib/[^"]*|<a href="https://docs.gtk.org/glib/|g' $FILE; \
        sed -i 's|<a[^>]* href="\.\./gobject/[^"]*|<a href="https://docs.gtk.org/gobject/|g' $FILE; \
        sed -i 's|<a[^>]* href="\.\./gio/[^"]*|<a href="https://docs.gtk.org/gio/|g' $FILE; \
      done

9) Upload the modified HTML files to freedesktop.org:
    $ scp html/* fd.o:${libqmi}/libqrtr-glib/${VERSION}/

10) For major releases:
     * Fork new stable branch (e.g. qrtr-${MAJOR}-${MINOR})
     * Post-release version bump in the master branch, increment qrtr_minor_version.
     * Post-release version bump in the stable branch, increment qrtr_micro_version.

11) For stable branch releases:
     * Post-release version bump, increment qrtr_micro_version.

-------------------------------------------------------------------------------

*) Verifying the signed tag requires the public key of the person who signed it,
   e.g.:

    $ curl https://www.freedesktop.org/software/libqrtr/0x3CAD53398973FFFA.asc | gpg --import