Last modified by christoph_lechleitner@iteg_at on 2018-01-03 03.50:49

From version 1.1
edited by christoph_lechleitner@iteg_at
on 2012-07-20 05.08:42
Change comment: There is no comment for this version
To version 18.1
edited by christoph_lechleitner@iteg_at
on 2016-12-06 03.54:51
Change comment: HInt mingw-5 removal

Summary

Details

Page properties
Title
... ... @@ -1,1 +1,1 @@
1 -PBA-cbs bootstrapping of portable C/C++ project
1 +PBA-cbs bootstrapping of portable C++ project
Content
... ... @@ -1,5 +1,161 @@
1 -I am preparing a full example to be checked out or exported from public svn.
1 +Setting up a portable C++ project still is a pain in the ass, especially if it shall be portable.
2 2  
3 -Soon ...
3 +When trying to automate it in some way, we came to the conclusion that a full example in a public subversion repository is a good solutions because it's easy to use for you and easy to maintain for us.
4 4  
5 +=== {{id name="PBA-cbsbootstrappingofportableC++project-HowTo..."/}}HowTo ... ===
6 +
7 +These are the steps for an ultra fast bootstrapping of a portable project relying on pba-cbs and [[our incarnation of the MinGW cross compilation toolchain>>doc:MINGW64.WebHome]].
8 +
9 +===== {{id name="PBA-cbsbootstrappingofportableC++project-Preparations"/}}Preparations =====
10 +
11 +You need deb sources for {{code language="none"}}pba{{/code}} ({{code language="none"}}any-pba-1.0{{/code}}) and //distro//{{code language="none"}}-mingw-5{{/code}} (i.e. {{code language="none"}}squeeze-mingw-5{{/code}} or {{code language="none"}}wheezy-mingw-5{{/code}}), see [[https:~~/~~/deb.clazzes.org>>url:https://deb.clazzes.org/||shape="rect"]].
12 +
13 +For starters, You need to install the packages {{code language="none"}}pba-cbs{{/code}} and {{code language="none"}}subversion{{/code}}.
14 +
15 +===== {{id name="PBA-cbsbootstrappingofportableC++project-Retrievethesceleton"/}}Retrieve the sceleton =====
16 +
17 +Decide for the main name of your app:
18 +
19 +{{code language="none"}}
20 +MYAPPNAME="myapp"
21 +{{/code}}
22 +
23 +Export our example from public svn:
24 +
25 +{{code language="none"}}
26 +# for a flat application project:
27 +svn export "https://svn.clazzes.org/svn/pba/trunk/pba-helloworld-portable" $MYAPPNAME
28 +
29 +# for a multi-module multi-program application project:
30 +svn export "https://svn.clazzes.org/svn/pba/trunk/pba-hellobigworld-portable" $MYAPPNAME
31
32 +# for a library project:
33 +svn export "https://svn.clazzes.org/svn/pba/trunk/pba-hellolib-portable" $MYAPPNAME
34 +{{/code}}
35 +
36 +===== {{id name="PBA-cbsbootstrappingofportableC++project-Renameandsearch'n'replace"/}}Rename and search'n'replace =====
37 +
38 +Rename some stuff and have the inlcude files adapted:
39 +
40 +{{code language="none"}}
41 +cd $MYAPPNAME
42
43 +scripts/rename_main_files.sh $MYAPPNAME
44
45 +rm scripts/rename_main_files.sh
46 +{{/code}}
47 +
48 +===== {{id name="PBA-cbsbootstrappingofportableC++project-Optional:Removewindowsstuff"/}}Optional: Remove windows stuff =====
49 +
50 +If you do not want windows binaries, remove it:
51 +
52 +(((
5 5  
54 +
55 +{{code language="none"}}
56 +# Variant 1: Remove NSIS installer only. For libraries common despite cross compilation.
57 +rm -rf nsis src/*.nsi
58 +
59 +# Variant 2: Remove NSIS installer and mingw-5
60 +rm -rf nsis src/*.nsi debian-mingw-5
61 +# Variant 3: Remove all windows crossbuilding stuff
62 +rm -rf nsis src/*.nsi src/include-mingw.mk src/*.rc debian-mingw* build/win*
63 +$EDITOR build/Makefile
64 +{{/code}}
65 +
66 +===== {{id name="PBA-cbsbootstrappingofportableC++project-Adaptdebianpackagemetainfos"/}}(% style="color: rgb(112,112,112);" %)Adapt debian package meta infos(%%) =====
67 +)))
68 +
69 +Change my name and e-mail to yours and adapt the description:
70 +
71 +{{code language="none"}}
72 +$EDITOR debian*/control debian*/changelog $(ls -1 src/*.pc.tmpl src/*.rc src/*.nsi src/*.h 2>/dev/null)
73 +{{/code}}
74 +
75 +(% style="color: rgb(51,51,51);" %)Do not forget to change the icon, too!
76 +
77 +===== {{id name="PBA-cbsbootstrappingofportableC++project-UpdateorremovetheReadMe"/}}Update or remove the ReadMe =====
78 +
79 +At least remove the link to this page ...
80 +
81 +{{code language="none"}}
82 +# edit ...
83 +$EDITOR doc/ReadMe.txt
84
85 +# ... or remove the file and the reference in debian*/rules
86 +rm doc/ReadMe.txt
87 +$EDITOR debian*/rules
88 +{{/code}}
89 +
90 +===== {{id name="PBA-cbsbootstrappingofportableC++project-Optional:Activatesvnoranotherrevisioncontrolsystem"/}}(% style="line-height: 1.6666666;" %)Optional: Activate svn or another revision control system(%%) =====
91 +
92 +Now (and before any build activity) is a very good time to put your project under subversion control:
93 +
94 +{{code language="none"}}
95 +svn add `pwd`
96 +{{/code}}
97 +
98 +You might also want to fill {{code language="none"}}svn:ignore{{/code}} properties of some directories:
99 +
100 +{{code language="none"}}
101 +scripts/set_svn_ignore.sh
102 +{{/code}}
103 +
104 +===== {{id name="PBA-cbsbootstrappingofportableC++project-Optional:Installrequiredlibsandbuildthepackage"/}}Optional: Install required libs and build the package =====
105 +
106 +To produce the debian packages, just:
107 +
108 +{{code language="none"}}
109 +# this needs sudo privileges
110 +pba-builddeps -i
111
112 +pba-build -u
113 +
114 +# or dpkg-build*
115 +{{/code}}
116 +
117 +To only build the linux packages or only the windows packages, add {{code language="none"}}-o unix{{/code}} resp. {{code language="none"}}-o mingw{{/code}} to the pba-commands.
118 +
119 +===== {{id name="PBA-cbsbootstrappingofportableC++project-Optional:CreateWindowsInstallers"/}}Optional: Create Windows Installers =====
120 +
121 +(Re)edit the {{code language="none"}}.nsi{{/code}} script template and replace all instances of "{{code language="none"}}Clazzes.org{{/code}}" with something of your choice:
122 +
123 +{{code language="none"}}
124 +$EDITOR src/*.nsi
125 +{{/code}}
126 +
127 +Then "make" the {{code language="none"}}nsis{{/code}} directory:
128 +
129 +{{code language="none"}}
130 +make -C nsis && ls -ltr nsis/*.exe
131 +{{/code}}
132 +
133 +===== {{id name="PBA-cbsbootstrappingofportableC++project-Optionalmulti-module/multi-programvariant:CreateModules,Programs"/}}Optional multi-module/multi-program variant: Create Modules, Programs =====
134 +
135 +{{code language="none"}}
136 +# create module common
137 +scripts/create_module.sh common
138
139 +# create program foobar-daemon
140 +scripts/create_program.sh foobar-daemon
141 +{{/code}}
142 +
143 +== {{id name="PBA-cbsbootstrappingofportableC++project-EclipseHints"/}}Eclipse Hints ==
144 +
145 +To create the Ecplise project, select File, New, Project..., C/C++, Makefile Project with existing code.
146 +
147 +The recommended Build Configurations and their Build directories are:
148 +
149 +{{code language="none"}}
150 +# Debug
151 +${ProjDirPath}/build/unix/debug
152
153 +# Release
154 +${ProjDirPath}/build/unix/release
155
156 +# Win32
157 +${ProjDirPath}/build/win32/release
158
159 +# Win64
160 +${ProjDirPath}/build/win64/release
161 +{{/code}}
Confluence.Code.ConfluencePageClass[0]
Id
... ... @@ -1,1 +1,1 @@
1 -659171
1 +659152
Title
... ... @@ -1,1 +1,1 @@
1 -PBA-cbs bootstrapping of portable C/C++ project
1 +PBA-cbs bootstrapping of portable C++ project
URL
... ... @@ -1,1 +1,1 @@
1 -https://clazzes.atlassian.net/wiki/spaces/PBA/pages/659171/PBA-cbs bootstrapping of portable C/C++ project
1 +https://clazzes.atlassian.net/wiki/spaces/PBA/pages/659152/PBA-cbs bootstrapping of portable C++ project