Version 15.1 by christoph_lechleitner@iteg_at on 2014-02-17 02.30:23

Show last authors
1 Setting up a portable C++ project still is a pain in the ass, especially if it shall be portable.
2
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
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 an application project:
27 svn export "https://svn.clazzes.org/svn/pba/trunk/pba-helloworld-portable" $MYAPPNAME
28  
29 # for a library project:
30 svn export "https://svn.clazzes.org/svn/pba/trunk/pba-hellolib-portable" $MYAPPNAME
31 {{/code}}
32
33 ===== {{id name="PBA-cbsbootstrappingofportableC++project-Renameandsearch'n'replace"/}}Rename and search'n'replace =====
34
35 Rename some stuff and have the inlcude files adapted:
36
37 {{code language="none"}}
38 cd $MYAPPNAME
39  
40 scripts/rename_main_files.sh $MYAPPNAME
41  
42 rm scripts/rename_main_files.sh
43 {{/code}}
44
45 ===== {{id name="PBA-cbsbootstrappingofportableC++project-Optional:Removewindowsstuff"/}}Optional: Remove windows stuff =====
46
47 If you do not want windows binaries, remove it:
48
49 (((
50
51
52 {{code language="none"}}
53 # Variant 1: Remove NSIS installer only. For libraries common despite cross compilation.
54 rm -rf nsis src/*.nsi
55  
56 # Variant 2: Remove all windows crossbuilding stuff
57 rm -rf nsis src/*.nsi src/include-mingw.mk src/*.rc debian-mingw* build/win*
58 $EDITOR build/Makefile
59 {{/code}}
60
61 ===== {{id name="PBA-cbsbootstrappingofportableC++project-Adaptdebianpackagemetainfos"/}}(% style="color: rgb(112,112,112);" %)Adapt debian package meta infos(%%) =====
62 )))
63
64 Change my name and e-mail to yours and adapt the description:
65
66 {{code language="none"}}
67 $EDITOR debian*/control debian*/changelog $(ls -1 src/*.pc.tmpl src/*.rc src/*.nsi src/*.h 2>/dev/null)
68 {{/code}}
69
70 (% style="color: rgb(51,51,51);" %)Do not forget to change the icon, too!
71
72 ===== {{id name="PBA-cbsbootstrappingofportableC++project-UpdateorremovetheReadMe"/}}Update or remove the ReadMe =====
73
74 At least remove the link to this page ...
75
76 {{code language="none"}}
77 # edit ...
78 $EDITOR doc/ReadMe.txt
79  
80 # ... or remove the file and the reference in debian*/rules
81 rm doc/ReadMe.txt
82 $EDITOR debian*/rules
83 {{/code}}
84
85 ===== {{id name="PBA-cbsbootstrappingofportableC++project-Optional:Activatesvnoranotherrevisioncontrolsystem"/}}(% style="line-height: 1.6666666;" %)Optional: Activate svn or another revision control system(%%) =====
86
87 Now (and before any build activity) is a very good time to put your project under subversion control:
88
89 {{code language="none"}}
90 svn add `pwd`
91 {{/code}}
92
93 You might also want to fill {{code language="none"}}svn:ignore{{/code}} properties of some directories:
94
95 {{code language="none"}}
96 scripts/set_svn_ignore.sh
97 {{/code}}
98
99 ===== {{id name="PBA-cbsbootstrappingofportableC++project-Optional:Installrequiredlibsandbuildthepackage"/}}Optional: Install required libs and build the package =====
100
101 To produce the debian packages, just:
102
103 {{code language="none"}}
104 # this needs sudo privileges
105 pba-builddeps -i
106  
107 pba-build -u
108
109 # or dpkg-build*
110 {{/code}}
111
112 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.
113
114 ===== {{id name="PBA-cbsbootstrappingofportableC++project-Optional:CreateWindowsInstallers"/}}Optional: Create Windows Installers =====
115
116 (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:
117
118 {{code language="none"}}
119 $EDITOR src/*.nsi
120 {{/code}}
121
122 Then "make" the {{code language="none"}}nsis{{/code}} directory:
123
124 {{code language="none"}}
125 make -C nsis && ls -ltr nsis/*.exe
126 {{/code}}
127
128 == {{id name="PBA-cbsbootstrappingofportableC++project-EclipseHints"/}}Eclipse Hints ==
129
130 To create the Ecplise project, select File, New, Project..., C/C++, Makefile Project with existing code.
131
132 The recommended Build Configurations and their Build directories are:
133
134
135
136 {{code language="none"}}
137 # Debug
138 ${ProjDirPath}/build/unix/debug
139  
140 # Release
141 ${ProjDirPath}/build/unix/release
142  
143 # Win32
144 ${ProjDirPath}/build/win32/release
145  
146 # Win64
147 ${ProjDirPath}/build/win64/release
148 {{/code}}