diff options
Diffstat (limited to 'bitbake/doc')
-rw-r--r-- | bitbake/doc/user-manual/user-manual-fetching.xml | 432 |
1 files changed, 271 insertions, 161 deletions
diff --git a/bitbake/doc/user-manual/user-manual-fetching.xml b/bitbake/doc/user-manual/user-manual-fetching.xml index cdca64c801..499d4f5198 100644 --- a/bitbake/doc/user-manual/user-manual-fetching.xml +++ b/bitbake/doc/user-manual/user-manual-fetching.xml | |||
@@ -2,84 +2,110 @@ | |||
2 | "http://www.oasis-open.org/docbook/xml/4.2/docbookx.dtd"> | 2 | "http://www.oasis-open.org/docbook/xml/4.2/docbookx.dtd"> |
3 | 3 | ||
4 | <chapter> | 4 | <chapter> |
5 | <title>File download support</title> | 5 | <title>File Download Support</title> |
6 | |||
7 | <para> | ||
8 | BitBake's <filename>fetch</filename> and | ||
9 | <filename>fetch2</filename> modules support downloading | ||
10 | files. | ||
11 | This chapter provides an overview of the fetching process | ||
12 | and also presents sections on each of the fetchers BitBake | ||
13 | supports. | ||
14 | <note> | ||
15 | The original <filename>fetch</filename> code, for all | ||
16 | practical purposes, has been replaced by | ||
17 | <filename>fetch2</filename> code. | ||
18 | Consequently, the information in this chapter does not | ||
19 | apply to <filename>fetch</filename>. | ||
20 | </note> | ||
21 | </para> | ||
6 | 22 | ||
7 | <section id='file-download-overview'> | 23 | <section id='file-download-overview'> |
8 | <title>Overview</title> | 24 | <title>Overview</title> |
9 | 25 | ||
10 | <para> | 26 | <para> |
11 | BitBake provides support to download files. | 27 | When BitBake starts to execute, the very first thing |
12 | This procedure is called fetching and is handled by the | 28 | it does is to fetch the source files needed. |
13 | fetch and fetch2 modules. | 29 | This section overviews the process. |
14 | At this point, the original fetch code is considered to | 30 | For some additional information on fetching source files, see the |
15 | be replaced by fetch2 and this manual is only related | 31 | "<link linkend='source-fetching-dev-environment'>Source Fetching</link>" |
16 | to the fetch2 codebase. | 32 | section. |
17 | </para> | 33 | </para> |
18 | 34 | ||
19 | <para> | 35 | <para> |
20 | The <filename>SRC_URI</filename> is normally used to | 36 | When BitBake goes looking for source files, it follows a search |
21 | tell BitBake which files to fetch. | 37 | order: |
22 | The next sections describe the available fetchers and | 38 | <orderedlist> |
23 | their options. | 39 | <listitem><para><emphasis>Pre-mirror Sites:</emphasis> |
24 | Each fetcher honors a set of variables and per | 40 | BitBake first uses pre-mirrors to try and find source |
25 | URI parameters separated by a “;” consisting of a key and | 41 | files. |
26 | a value. | 42 | These locations are defined using the |
27 | The semantics of the variables and parameters are | 43 | <link linkend='var-PREMIRRORS'><filename>PREMIRRORS</filename></link> |
28 | defined by the fetcher. | 44 | variable. |
29 | BitBake tries to have consistent semantics between the | 45 | </para></listitem> |
30 | different fetchers. | 46 | <listitem><para><emphasis>Source URI:</emphasis> |
47 | If pre-mirrors fail, BitBake uses | ||
48 | <link linkend='var-SRC_URI'><filename>SRC_URI</filename></link>. | ||
49 | </para></listitem> | ||
50 | <listitem><para><emphasis>Mirror Sites:</emphasis> | ||
51 | If fetch failures occur using <filename>SRC_URI</filename>, | ||
52 | BitBake next uses mirror location as defined by the | ||
53 | <link linkend='var-MIRRORS'><filename>MIRRORS</filename></link> | ||
54 | variable. | ||
55 | </para></listitem> | ||
56 | </orderedlist> | ||
31 | </para> | 57 | </para> |
32 | 58 | ||
33 | <para> | 59 | <para> |
34 | The overall fetch process first attempts to fetch from | ||
35 | <filename>PREMIRRORS</filename>. | ||
36 | If these fail, the original <filename>SRC_URI</filename> | ||
37 | is attempted. | ||
38 | If that fails, BitBake falls back to | ||
39 | <filename>MIRRORS</filename>. | ||
40 | Because cross-URLs are supported, it is possible to mirror | 60 | Because cross-URLs are supported, it is possible to mirror |
41 | a Git repository on an HTTP server as a tarball. | 61 | a Git repository on an HTTP server as a tarball. |
42 | Here are some examples that show commonly used mirror | 62 | Here are some examples that show commonly used mirror |
43 | definitions: | 63 | definitions: |
44 | <literallayout class='monospaced'> | 64 | <literallayout class='monospaced'> |
45 | PREMIRRORS ?= "\ | 65 | PREMIRRORS ?= "\ |
46 | bzr://.*/.* http://somemirror.org/sources/ \n \ | 66 | bzr://.*/.* http://somemirror.org/sources/ \n \ |
47 | cvs://.*/.* http://somemirror.org/sources/ \n \ | 67 | cvs://.*/.* http://somemirror.org/sources/ \n \ |
48 | git://.*/.* http://somemirror.org/sources/ \n \ | 68 | git://.*/.* http://somemirror.org/sources/ \n \ |
49 | hg://.*/.* http://somemirror.org/sources/ \n \ | 69 | hg://.*/.* http://somemirror.org/sources/ \n \ |
50 | osc://.*/.* http://somemirror.org/sources/ \n \ | 70 | osc://.*/.* http://somemirror.org/sources/ \n \ |
51 | p4://.*/.* http://somemirror.org/sources/ \n \ | 71 | p4://.*/.* http://somemirror.org/sources/ \n \ |
52 | svk://.*/.* http://somemirror.org/sources/ \n \ | 72 | svk://.*/.* http://somemirror.org/sources/ \n \ |
53 | svn://.*/.* http://somemirror.org/sources/ \n" | 73 | svn://.*/.* http://somemirror.org/sources/ \n" |
54 | 74 | ||
55 | MIRRORS =+ "\ | 75 | MIRRORS =+ "\ |
56 | ftp://.*/.* http://somemirror.org/sources/ \n \ | 76 | ftp://.*/.* http://somemirror.org/sources/ \n \ |
57 | http://.*/.* http://somemirror.org/sources/ \n \ | 77 | http://.*/.* http://somemirror.org/sources/ \n \ |
58 | https://.*/.* http://somemirror.org/sources/ \n" | 78 | https://.*/.* http://somemirror.org/sources/ \n" |
59 | </literallayout> | 79 | </literallayout> |
60 | </para> | 80 | </para> |
61 | 81 | ||
62 | <para> | 82 | <para> |
63 | Non-local downloaded output is placed | 83 | Any source files that are not local (i.e. downloaded from |
64 | into the directory specified by the | 84 | the Internet) are placed into the download directory, |
65 | <filename>DL_DIR</filename> variable. | 85 | which is specified by |
66 | For non local archive downloads, the code can verify | 86 | <link linkend='var-DL_DIR'><filename>DL_DIR</filename></link>. |
67 | sha256 and md5 checksums for the download to ensure | 87 | </para> |
68 | the file has been downloaded correctly. | 88 | |
69 | These can be specified in the following forms | 89 | <para> |
70 | for md5 and sha256 checksums, respectively: | 90 | For non-local archive downloads, the fetcher code can verify |
91 | sha256 and md5 checksums to ensure | ||
92 | the archives have been downloaded correctly. | ||
93 | You can specify these checksums by using the | ||
94 | <filename>SRC_URI</filename> variable with the appropriate | ||
95 | varflags as follows: | ||
71 | <literallayout class='monospaced'> | 96 | <literallayout class='monospaced'> |
72 | SRC_URI[md5sum] | 97 | SRC_URI[md5sum] |
73 | SRC_URI[sha256sum] | 98 | SRC_URI[sha256sum] |
74 | </literallayout> | 99 | </literallayout> |
75 | You can also specify them as parameters on the | 100 | You can also specify the checksums as parameters on the |
76 | <filename>SRC_URI</filename>: | 101 | <filename>SRC_URI</filename> as shown below: |
77 | <literallayout class='monospaced'> | 102 | <literallayout class='monospaced'> |
78 | SRC_URI="http://example.com/foobar.tar.bz2;md5sum=4a8e0f237e961fd7785d19d07fdb994d" | 103 | SRC_URI="http://example.com/foobar.tar.bz2;md5sum=4a8e0f237e961fd7785d19d07fdb994d" |
79 | </literallayout> | 104 | </literallayout> |
80 | If <filename>BB_STRICT_CHECKSUM</filename> is set, any download | 105 | If |
81 | without a checksum will trigger an error message. | 106 | <link linkend='var-BB_STRICT_CHECKSUM'><filename>BB_STRICT_CHECKSUM</filename></link> |
82 | In cases where multiple files are listed in | 107 | is set, any download without a checksum triggers an error message. |
108 | In cases where multiple files are listed using | ||
83 | <filename>SRC_URI</filename>, the name parameter is used | 109 | <filename>SRC_URI</filename>, the name parameter is used |
84 | assign names to the URLs and these are then specified | 110 | assign names to the URLs and these are then specified |
85 | in the checksums using the following form: | 111 | in the checksums using the following form: |
@@ -89,142 +115,226 @@ MIRRORS =+ "\ | |||
89 | </para> | 115 | </para> |
90 | </section> | 116 | </section> |
91 | 117 | ||
92 | <section id='local-file-fetcher'> | 118 | <section id='bb-fetchers'> |
93 | <title>Local file fetcher</title> | 119 | <title>Fetchers</title> |
94 | 120 | ||
95 | <para> | 121 | <para> |
96 | The URN for the local file fetcher is file. | 122 | As mentioned in the previous section, the |
97 | The filename can be either absolute or relative. | 123 | <filename>SRC_URI</filename> is normally used to |
98 | If the filename is relative, | 124 | tell BitBake which files to fetch. |
99 | <filename>FILESPATH</filename> and failing that | 125 | And, the fetcher BitBake uses depends on the how |
100 | <filename>FILESDIR</filename> will be used to find the | 126 | <filename>SRC_URI</filename> is set. |
101 | appropriate relative file. | 127 | </para> |
102 | The metadata usually extend these variables to include | 128 | |
103 | variations of the values in <filename>OVERRIDES</filename>. | 129 | <para> |
104 | Single files and complete directories can be specified. | 130 | These next few sections describe the available fetchers and |
105 | <literallayout class='monospaced'> | 131 | their options. |
132 | Each fetcher honors a set of variables URI parameters, | ||
133 | which are separated by semi-colon characters and consist | ||
134 | of a key and a value. | ||
135 | The semantics of the variables and parameters are | ||
136 | defined by the fetcher. | ||
137 | BitBake tries to have consistent semantics between the | ||
138 | different fetchers. | ||
139 | </para> | ||
140 | |||
141 | <section id='local-file-fetcher'> | ||
142 | <title>Local file fetcher</title> | ||
143 | |||
144 | <para> | ||
145 | The URN for the local file fetcher is file. | ||
146 | </para> | ||
147 | |||
148 | <para> | ||
149 | The filename can be either absolute or relative. | ||
150 | If the filename is relative, | ||
151 | <link linkend='var-FILESPATH'><filename>FILESPATH</filename></link> | ||
152 | is used. | ||
153 | Failing that, | ||
154 | <link linkend='var-FILESDIR'><filename>FILESDIR</filename></link> | ||
155 | is used to find the appropriate relative file. | ||
156 | </para> | ||
157 | |||
158 | <para> | ||
159 | The metadata usually extend these variables to include | ||
160 | variations of the values in | ||
161 | <link linkend='var-OVERRIDES'><filename>OVERRIDES</filename></link>. | ||
162 | Single files and complete directories can be specified. | ||
163 | <literallayout class='monospaced'> | ||
106 | SRC_URI = "file://relativefile.patch" | 164 | SRC_URI = "file://relativefile.patch" |
107 | SRC_URI = "file://relativefile.patch;this=ignored" | 165 | SRC_URI = "file://relativefile.patch;this=ignored" |
108 | SRC_URI = "file:///Users/ich/very_important_software" | 166 | SRC_URI = "file:///Users/ich/very_important_software" |
109 | </literallayout> | 167 | </literallayout> |
110 | </para> | 168 | </para> |
111 | </section> | 169 | </section> |
112 | 170 | ||
113 | <section id='cvs-fetcher'> | 171 | <section id='cvs-fetcher'> |
114 | <title>CVS fetcher</title> | 172 | <title>CVS fetcher</title> |
115 | 173 | ||
116 | <para> | 174 | <para> |
117 | The URN for the CVS fetcher is cvs. | 175 | The URN for the CVS fetcher is cvs. |
118 | This fetcher honors the variables <filename>CVSDIR</filename>, | 176 | </para> |
119 | <filename>SRCDATE</filename>, <filename>FETCHCOMMAND_cvs</filename>, | ||
120 | <filename>UPDATECOMMAND_cvs</filename>. | ||
121 | <filename>DL_DIR</filename> specifies where a | ||
122 | temporary checkout is saved. | ||
123 | <filename>SRCDATE</filename> specifies which date to | ||
124 | use when doing the fetching (the special value of "now" | ||
125 | will cause the checkout to be updated on every build). | ||
126 | <filename>FETCHCOMMAND</filename> and | ||
127 | <filename>UPDATECOMMAND</filename> specify which executables | ||
128 | to use for the CVS checkout or update. | ||
129 | </para> | ||
130 | 177 | ||
131 | <para> | 178 | <para> |
132 | The supported parameters are module, tag, date, | 179 | This fetcher honors the variables <filename>CVSDIR</filename>, |
133 | method, localdir, rshand scmdata. | 180 | <filename>SRCDATE</filename>, <filename>FETCHCOMMAND_cvs</filename>, |
134 | The module specifies which module to check out, | 181 | <filename>UPDATECOMMAND_cvs</filename>. |
135 | the tag describes which CVS TAG should be used for | 182 | The |
136 | the checkout. | 183 | <link linkend='var-DL_DIR'><filename>DL_DIR</filename></link> |
137 | By default, the TAG is empty. | 184 | variable specifies where a |
138 | A date can be specified to override the | 185 | temporary checkout is saved. |
139 | <filename>SRCDATE</filename> of the | 186 | The |
140 | configuration to checkout a specific date. | 187 | <link linkend='var-SRCDATE'><filename>SRCDATE</filename></link> |
141 | The special value of "now" will cause the checkout to be | 188 | variable specifies which date to |
142 | updated on every build. | 189 | use when doing the fetching. |
143 | method is by default pserver. | 190 | The special value of "now" causes the checkout to be |
144 | If ext is used the rsh parameter will be evaluated | 191 | updated on every build. |
145 | and <filename>CVS_RSH</filename> will be set. | 192 | The <filename>FETCHCOMMAND</filename> and |
146 | Finally, localdir is used to checkout into a special | 193 | <filename>UPDATECOMMAND</filename> variables specify the executables |
147 | directory relative to <filename>CVSDIR</filename>. | 194 | to use for the CVS checkout or update. |
148 | <literallayout class='monospaced'> | 195 | </para> |
196 | |||
197 | <para> | ||
198 | The supported parameters are as follows: | ||
199 | <itemizedlist> | ||
200 | <listitem><para><emphasis>"module":</emphasis> | ||
201 | Specifies the module to check out. | ||
202 | </para></listitem> | ||
203 | <listitem><para><emphasis>"tag":</emphasis> | ||
204 | Describes which CVS TAG should be used for | ||
205 | the checkout. | ||
206 | By default, the TAG is empty. | ||
207 | </para></listitem> | ||
208 | <listitem><para><emphasis>"date":</emphasis> | ||
209 | Specifies a date. | ||
210 | If no "date" is specified, the | ||
211 | <link linkend='var-SRCDATE'><filename>SRCDATE</filename></link> | ||
212 | of the configuration is used to checkout a specific date. | ||
213 | The special value of "now" causes the checkout to be | ||
214 | updated on every build. | ||
215 | </para></listitem> | ||
216 | <listitem><para><emphasis>"method":</emphasis> | ||
217 | By default <filename>pserver</filename>. | ||
218 | If "method" is set to "ext", BitBake examines the "rsh" | ||
219 | parameter and sets <filename>CVS_RSH</filename>. | ||
220 | </para></listitem> | ||
221 | <listitem><para><emphasis>"localdir":</emphasis> | ||
222 | Used to checkout force into a special | ||
223 | directory relative to <filename>CVSDIR</filename>. | ||
224 | </para></listitem> | ||
225 | <listitem><para><emphasis>"rsh"</emphasis> | ||
226 | Used in conjunction with the "method" parameter. | ||
227 | </para></listitem> | ||
228 | <listitem><para><emphasis>"scmdata":</emphasis> | ||
229 | I need a description for this. | ||
230 | </para></listitem> | ||
231 | </itemizedlist> | ||
232 | Following are two examples using cvs: | ||
233 | <literallayout class='monospaced'> | ||
149 | SRC_URI = "cvs://CVSROOT;module=mymodule;tag=some-version;method=ext" | 234 | SRC_URI = "cvs://CVSROOT;module=mymodule;tag=some-version;method=ext" |
150 | SRC_URI = "cvs://CVSROOT;module=mymodule;date=20060126;localdir=usethat" | 235 | SRC_URI = "cvs://CVSROOT;module=mymodule;date=20060126;localdir=usethat" |
151 | </literallayout> | 236 | </literallayout> |
152 | </para> | 237 | </para> |
153 | </section> | 238 | </section> |
154 | 239 | ||
155 | <section id='http-ftp-fetcher'> | 240 | <section id='http-ftp-fetcher'> |
156 | <title>HTTP/FTP fetcher</title> | 241 | <title>HTTP/FTP fetcher</title> |
157 | 242 | ||
158 | <para> | 243 | <para> |
159 | The URNs for the HTTP/FTP fetcher are http, https, and ftp. | 244 | The URNs for the HTTP/FTP fetcher are http, https, and ftp. |
160 | This fetcher honors the variables | 245 | </para> |
161 | <filename>FETCHCOMMAND_wget</filename>. | 246 | |
162 | <filename>FETCHCOMMAND</filename> contains the command used | 247 | <para> |
163 | for fetching. | 248 | This fetcher honors the variables |
164 | “${URI}” and “${FILES}” will be replaced by the URI and | 249 | <filename>FETCHCOMMAND_wget</filename>. |
165 | basename of the file to be fetched. | 250 | The <filename>FETCHCOMMAND</filename> variable |
166 | <literallayout class='monospaced'> | 251 | contains the command used for fetching. |
252 | “${URI}” and “${FILES}” are replaced by the URI and | ||
253 | the base name of the file to be fetched. | ||
254 | <literallayout class='monospaced'> | ||
167 | SRC_URI = "http://oe.handhelds.org/not_there.aac" | 255 | SRC_URI = "http://oe.handhelds.org/not_there.aac" |
168 | SRC_URI = "ftp://oe.handhelds.org/not_there_as_well.aac" | 256 | SRC_URI = "ftp://oe.handhelds.org/not_there_as_well.aac" |
169 | SRC_URI = "ftp://you@oe.handheld.sorg/home/you/secret.plan" | 257 | SRC_URI = "ftp://you@oe.handheld.sorg/home/you/secret.plan" |
170 | </literallayout> | 258 | </literallayout> |
171 | </para> | 259 | </para> |
172 | </section> | 260 | </section> |
173 | 261 | ||
174 | <section id='svn-fetcher'> | 262 | <section id='svn-fetcher'> |
175 | <title>SVN Fetcher</title> | 263 | <title>SVN Fetcher</title> |
176 | 264 | ||
177 | <para> | 265 | <para> |
178 | The URN for the SVN fetcher is svn. | 266 | The URN for the SVN fetcher is svn. |
179 | </para> | 267 | </para> |
180 | 268 | ||
181 | <para> | 269 | <para> |
182 | This fetcher honors the variables | 270 | This fetcher honors the variables |
183 | <filename>FETCHCOMMAND_svn</filename>, | 271 | <filename>FETCHCOMMAND_svn</filename>, |
184 | <filename>SVNDIR</filename>, | 272 | <filename>SVNDIR</filename>, |
185 | and <filename>SRCREV</filename>. | 273 | and |
186 | <filename>FETCHCOMMAND</filename> contains the | 274 | <link linkend='var-SRCREV'><filename>SRCREV</filename></link>. |
187 | subversion command. | 275 | The <filename>FETCHCOMMAND</filename> variable contains the |
188 | <filename>SRCREV</filename> specifies which revision | 276 | <filename>subversion</filename> command. |
189 | to use when doing the fetching. | 277 | The <filename>SRCREV</filename> variable specifies which revision |
190 | </para> | 278 | to use when doing the fetching. |
279 | </para> | ||
191 | 280 | ||
192 | <para> | 281 | <para> |
193 | The supported parameters are proto, rev and scmdata. | 282 | The supported parameters are as follows: |
194 | proto is the Subversion protocol, rev is the | 283 | <itemizedlist> |
195 | Subversion revision. | 284 | <listitem><para><emphasis>"proto":</emphasis> |
196 | If scmdata is set to “keep”, the “.svn” directories will | 285 | The Subversion protocol. |
197 | be available during compile-time. | 286 | </para></listitem> |
198 | <literallayout class='monospaced'> | 287 | <listitem><para><emphasis>"rev":</emphasis> |
288 | The Subversion revision. | ||
289 | </para></listitem> | ||
290 | <listitem><para><emphasis>"scmdata":</emphasis> | ||
291 | Set to "keep" causes the “.svn” directories | ||
292 | to be available during compile-time. | ||
293 | </para></listitem> | ||
294 | </itemizedlist> | ||
295 | Following are two examples using svn: | ||
296 | <literallayout class='monospaced'> | ||
199 | SRC_URI = "svn://svn.oe.handhelds.org/svn;module=vip;proto=http;rev=667" | 297 | SRC_URI = "svn://svn.oe.handhelds.org/svn;module=vip;proto=http;rev=667" |
200 | SRC_URI = "svn://svn.oe.handhelds.org/svn/;module=opie;proto=svn+ssh;date=20060126" | 298 | SRC_URI = "svn://svn.oe.handhelds.org/svn/;module=opie;proto=svn+ssh;date=20060126" |
201 | </literallayout> | 299 | </literallayout> |
202 | </para> | 300 | </para> |
203 | </section> | 301 | </section> |
204 | 302 | ||
205 | <section id='git-fetcher'> | 303 | <section id='git-fetcher'> |
206 | <title>GIT Fetcher</title> | 304 | <title>GIT Fetcher</title> |
207 | 305 | ||
208 | <para> | 306 | <para> |
209 | The URN for the GIT Fetcher is git. | 307 | The URN for the Git Fetcher is git. |
210 | </para> | 308 | </para> |
211 | 309 | ||
212 | <para> | 310 | <para> |
213 | The variable <filename>GITDIR</filename> will be used as the | 311 | The variable <filename>GITDIR</filename> is used as the |
214 | base directory where the Git tree is cloned to. | 312 | base directory in which the Git tree is cloned. |
215 | </para> | 313 | </para> |
216 | 314 | ||
217 | <para> | 315 | <para> |
218 | The parameters are tag, protocol, and scmdata. | 316 | The supported parameters are as follows: |
219 | The tag parameter is a Git tag, the default is “master”. | 317 | <itemizedlist> |
220 | The protocol tag is the Git protocol to use and defaults to “git” | 318 | <listitem><para><emphasis>"tag":</emphasis> |
221 | if a hostname is set, otherwise it is “file”. | 319 | The Git tag. |
222 | If scmdata is set to “keep”, the “.git” directory will be available | 320 | The default is "master". |
223 | during compile-time. | 321 | </para></listitem> |
224 | <literallayout class='monospaced'> | 322 | <listitem><para><emphasis>"protocol":</emphasis> |
323 | The Git protocol. | ||
324 | The default is "git" when a hostname is set. | ||
325 | If a hostname is not set, the Git protocol is "file". | ||
326 | </para></listitem> | ||
327 | <listitem><para><emphasis>"scmdata":</emphasis> | ||
328 | When set to “keep”, the “.git” directory is available | ||
329 | during compile-time. | ||
330 | </para></listitem> | ||
331 | </itemizedlist> | ||
332 | Following are two examples using git: | ||
333 | <literallayout class='monospaced'> | ||
225 | SRC_URI = "git://git.oe.handhelds.org/git/vip.git;tag=version-1" | 334 | SRC_URI = "git://git.oe.handhelds.org/git/vip.git;tag=version-1" |
226 | SRC_URI = "git://git.oe.handhelds.org/git/vip.git;protocol=http" | 335 | SRC_URI = "git://git.oe.handhelds.org/git/vip.git;protocol=http" |
227 | </literallayout> | 336 | </literallayout> |
228 | </para> | 337 | </para> |
338 | </section> | ||
229 | </section> | 339 | </section> |
230 | </chapter> | 340 | </chapter> |