Last modified by christoph_lechleitner@iteg_at on 2025-08-11 12.45:34

From version 8.1
edited by christoph_lechleitner@iteg_at
on 2023-03-24 08.55:42
Change comment: Started on Debian 12 Bookworm
To version 5.1
edited by christoph_lechleitner@iteg_at
on 2019-03-23 09.45:46
Change comment: \n, link to fancylibs adaption

Summary

Details

Page properties
Content
... ... @@ -2,22 +2,20 @@
2 2  
3 3  About every 2 years Debian introduces a new release.
4 4  
5 -The following notes shall provide a step-by-step-plan for adapting the [[PBA Package Builder + Archiver>>doc:PBA.WebHome]] to a new Debian release and shall make it more efficient for the next Debian.
5 +At the time I'm writing this Debian [[Buster>>url:https://wiki.debian.org/DebianBuster||shape="rect"]] is on it's way from Full Freeze to GA.
6 6  
7 -The first version of this page was created when Debian [[Buster>>url:https://wiki.debian.org/DebianBuster||shape="rect"]] was on it's way from Full Freeze to GA, we were still using {{code language="none"}}svn{{/code}} back then (mostly {{code language="none"}}git{{/code}} now).
7 +The following notes shall provide a step-by-step-plan for adapting the [[PBA Package Builder + Archiver>>doc:PBA.WebHome]] to a new Debian release and shall make it more efficient for the next Debian or maybe Ubuntu release.
8 8  
9 -Currently we are in the progress of adapting from [[Bullseye>>url:https://wiki.debian.org/DebianBullseye||shape="rect"]] to [[Bookworm>>url:https://wiki.debian.org/DebianBookworm||shape="rect"]], so this is __WORK IN PROGRESS__ rg. Bookworm.
10 -
11 11  = {{id name="AdaptingPBAtonewDebianRelease-AdaptingpbatonewDebianRelease"/}}Adapting pba to new Debian Release =
12 12  
13 13  === {{id name="AdaptingPBAtonewDebianRelease-Preprations"/}}Preprations ===
14 14  
15 15  {{code}}
16 -OLDDN=bullseye
17 -NEWDN=bookworm
14 +OLDREL=stretch
15 +NEWREL=buster
18 18  
19 -# we prefix name of feature branches issue number or epic numbers
20 -ISSUENR="8" ; BRANCHNAME="${ISSUENR}_adapt_to_debian_${NEWDN}" ; echo "Branch name: ${BRANCHNAME}"
17 +cd ~/sources/pba/trunk/pba
18 +svn up ..
21 21  {{/code}}
22 22  
23 23  === {{id name="AdaptingPBAtonewDebianRelease-Adaptionsforphase1,towardsGA"/}}Adaptions for phase 1, towards GA ===
... ... @@ -25,120 +25,85 @@
25 25  In phase 1 we make the new distribution known in the sense of adding a template for distributions.d/.
26 26  
27 27  {{code}}
28 -cd ~/sources/pba/pba/pba
26 +cat src/etc/pba/distributions.d/${OLDREL} |sed -e "s/${OLDREL}/${NEWREL}/g" >src/etc/pba/distributions.d/${NEWREL}
27 +svn add src/etc/pba/distributions.d/${NEWREL}
29 29  
30 -git checkout main ; git pull ; git checkout main
31 -
32 -git branch ${BRANCHNAME} && git checkout ${BRANCHNAME} && git status
33 -
34 -git push --set-upstream origin ${BRANCHNAME}
35 -
36 -cat src/etc/pba/distributions.d/${OLDDN} |sed -e "s/${OLDDN}/${NEWDN}/g" >src/etc/pba/distributions.d/${NEWDN}
37 -${EDITOR:-vi} src/etc/pba/distributions.d/${NEWDN}
38 -
39 -git add src/etc/pba/distributions.d/${NEWDN}
40 -
41 41  # evtl. drop ancient ones
42 -git rm src/etc/pba/distributions.d/foobar
30 +svn rm src/etc/pba/distributions.d/
43 43  
44 -pba-raiseversion
45 -
46 -pba-raiseversion -b 1.6.31-0 "Adapting to distribution Debian 12 Bookworm"
47 -
48 -${EDITOR:-vi} debian-unix/rules debian*/pba-common.install src/etc/pba/distributions.d/${NEWDN}
49 -# debian-unix/control
32 +${EDITOR:-vi} debian/changelog debian/rules debian/pba-common.install src/etc/pba/distributions.d/${NEWREL} debian/control
50 50  # src/etc/pba/builder.conf.template src/lib/build-functions.pl
51 51  
52 52  # commit
53 -git commit -m "Adding support for new Debian distro ${NEWDN}"
36 +svn commit -m "Adding support for new Debian distro ${NEWREL}"
54 54  
55 -git push
56 -
57 -# evtl. release it locally, or in Gitlab
38 +# release it
58 58  pba-release
59 -
60 -
61 61  {{/code}}
62 62  
63 -=== {{id name="AdaptingPBAtonewDebianRelease----currentpointofadaptiontoDebianBookworm---"/}}**~-~-- current point of adaption to Debian Bookworm ~-~--** ===
64 -
65 -=== {{id name="AdaptingPBAtonewDebianRelease-CreatePBA-Buildertarballs"/}}Create PBA-Builder tarballs ===
66 -
67 -See eventual separate notes (my [[ITEG's PBA-Tarball Notes>>url:https://confluence.iteg.at/x/l4Kg||shape="rect"]] are not public, sorry).
68 -
69 69  === {{id name="AdaptingPBAtonewDebianRelease-AdaptHelloWorldProjects"/}}Adapt HelloWorld Projects ===
70 70  
71 71  {{code language="none"}}
72 72  cd ~/sources/pba/trunk/pba-helloworld
46 +svn up ..
73 73  
74 -git checkout main ; git pull ; git checkout main
75 -
76 -git branch ${BRANCHNAME} && git checkout ${BRANCHNAME} && git status
77 -
78 -git push --set-upstream origin ${BRANCHNAME}
79 -
80 -pba-raiseversion
81 -# decide next version
82 -pba-raisversion -b 1.2.3 "Adding new Debian target distro ${NEWDN}"
83 -
84 -git add debian*/control debian*/changelog
85 -
86 -PBAO="."
48 +PBAO=""
87 87  # or
88 -PBAO="arch|unix"
89 -# or in phase 2 or when combining
90 -PBAO="arch|unix|7"
50 +PBAO='-o unix'
91 91  
92 -#pba-builddeps -i -o ${PBAO}
52 +pba-builddeps -i ${PBAO}
93 93  
94 -#pba-instdeps -i -o ${PBAO}
54 +#pba-instdeps -i ${PBAO}
95 95  
96 -pba-build -u -i -o ${PBAO}
56 +pba-build -u -i ${PBAO}
97 97  
98 98  # solve eventual problems
99 99  
100 -PBADD=$(ls -1d debian* |grep -v mingw |head -1)
101 -${EDITOR:-vi} ${PBADD}/changelog ${PBADD}/control
60 +${EDITOR:-vi} debian/changelog debian/control
61 +# or
62 +${EDITOR:-vi} debian-unix/changelog debian-unix/control
102 102  
103 -pba-localbuild -u -o ${PBAO}
64 +pba-syncchangelogs
104 104  
105 -# evtl.
106 -#pba-localrpmbuild -u -o ${PBAO}
66 +pba-release -u -b pba-spool/ ${PBAO}
67 +sudo pba-builder -B pba-spool -b pba-results ${PBAO} 2>&1 |tee pba-builder.log
107 107  
108 108  # wait for success
109 109  
110 -git commit -m "Adding support for new Debian distro ${NEWDN}"
111 -git push
71 +sudo rm -rf pba-spool/ pba-results pba-builder.log
112 112  
113 -# optional, eventually after merge in main
114 -pba-release -o ${PBAO}
73 +svn commit -m "Adding support for new Debian distro ${NEWREL}"
115 115  
75 +pba-release ${PBAO}
116 116  
77 +
117 117  {{/code}}
118 118  
119 -LATER (after adapting Fancylibs below) repeat for {{code language="none"}}pba-helloworld-portable{{/code}} (with {{code language="none"}}-o unix{{/code}}).
80 +Repeat for pba-hellolib-portable (with -o unix).
120 120  
121 -Repeat for {{code language="none"}}pba-hellolib-portable{{/code}} (with {{code language="none"}}-o unix{{/code}}).
82 +Repeat for pba-hellobigworld-portable (with -o unix).
122 122  
123 -Repeat for {{code language="none"}}pba-hellobigworld-portable{{/code}} (with {{code language="none"}}-o unix{{/code}}).
84 +... with (% style="letter-spacing: 0.0px;" %){{code language="none"}}-o unix{{/code}}(%%) or later (% style="letter-spacing: 0.0px;" %){{code language="none"}}-o "unix|7"{{/code}}(%%).
124 124  
125 -... with (% style="letter-spacing: 0.0px;" %){{code language="none"}}-o unix{{/code}}(%%) or later (% style="letter-spacing: 0.0px;" %){{code language="none"}}-o "unix|9"{{/code}}(%%).
126 -
127 127  === {{id name="AdaptingPBAtonewDebianRelease-AdaptFANCYLIBS"/}}Adapt [[doc:FANCYLIBS.WebHome]] ===
128 128  
129 -See [[Adapting FancyLibs & MinGW-Pkg from Debian 9 Stretch to 10 Buster, Mingw-7 to Mingw-8>>doc:FANCYLIBS.Adapting FancyLibs & MinGW-Pkg from Debian 9 Stretch to 10 Buster, Mingw-7 to Mingw-8.WebHome]].
88 +See [[confluencePage:page:FANCYLIBS.Adapting FancyLibs to new Debian Release]],
130 130  
131 131  === {{id name="AdaptingPBAtonewDebianRelease-Adaptpba-helloworld-portable"/}}Adapt pba-helloworld-portable ===
132 132  
133 -See above, use {{code language="none"}}-o unix{{/code}}.
92 +See above, use -o unix.
134 134  
94 +=== {{id name="AdaptingPBAtonewDebianRelease-CreatePBA-Buildertarballs"/}}Create PBA-Builder tarballs ===
95 +
96 +See eventual separate notes (my [[ITEG's PBA-Tarball Notes>>url:https://confluence.iteg.at/x/l4Kg||shape="rect"]] are not public, sorry).
97 +
135 135  === {{id name="AdaptingPBAtonewDebianRelease-AdaptMinGW"/}}Adapt [[MinGW>>doc:MINGW64.WebHome]] ===
136 136  
137 137  See [[doc:MINGW64.mingw 6 rebuild order.WebHome]].
138 138  
139 -=== {{id name="AdaptingPBAtonewDebianRelease-MinGW-Adaptpba-hello*-portable"/}}MinGW-Adapt pba-hello*-portable ===
102 +=== {{id name="AdaptingPBAtonewDebianRelease-Adaptpba-hello*-portable"/}}Adapt pba-hello*-portable ===
140 140  
141 -See above, with -o "unix|9" instead of "-o unix".
104 +See above, with -o "unix|7" instead of "-o unix".
142 142  
143 143  === {{id name="AdaptingPBAtonewDebianRelease-Adaptionsforphase2,oncenewreleaseissettled"/}}Adaptions for phase 2, once new release is settled ===
144 144  
... ... @@ -148,7 +148,7 @@
148 148  ${EDITOR:-vi} debian/changelog src/etc/pba/builder.conf.template src/lib/build-functions.pl
149 149  
150 150  # commit
151 -git commit -m "Making new Debian distro ${NEWDN} default for DefaultDistribution in pba-builder.conf"
114 +svn commit -m "Making new Debian distro ${NEWREL} default for DefaultDistribution in pba-builder.conf"
152 152  
153 153  # release it
154 154  pba-release
Confluence.Code.ConfluencePageClass[0]
Id
... ... @@ -1,1 +1,1 @@
1 -968687752
1 +659138
URL
... ... @@ -1,1 +1,1 @@
1 -https://clazzes.atlassian.net/wiki/spaces/PBA/pages/968687752/Adapting PBA to new Debian Release
1 +https://clazzes.atlassian.net/wiki/spaces/PBA/pages/659138/Adapting PBA to new Debian Release