(Initial import): Fix. Mention --aux-dir.
[pspp] / doc / gnulib.texi
1 \input texinfo   @c -*-texinfo-*-
2 @comment $Id: gnulib.texi,v 1.7 2005-04-18 20:58:20 jas Exp $
3 @comment %**start of header
4 @setfilename gnulib.info
5 @settitle GNU Gnulib
6 @syncodeindex fn cp
7 @syncodeindex pg cp
8 @comment %**end of header
9
10 @set UPDATED $Date: 2005-04-18 20:58:20 $
11
12 @copying
13 This manual is for GNU Gnulib (updated @value{UPDATED}),
14 which is a library of common routines intended to be shared at the
15 source level.
16
17 Copyright @copyright{} 2004 Free Software Foundation, Inc.
18
19 @quotation
20 Permission is granted to copy, distribute and/or modify this document
21 under the terms of the GNU Free Documentation License, Version 1.1 or
22 any later version published by the Free Software Foundation; with no
23 Invariant Sections, with the Front-Cover Texts being ``A GNU Manual,''
24 and with the Back-Cover Texts as in (a) below.  A copy of the
25 license is included in the section entitled ``GNU Free Documentation
26 License.''
27
28 (a) The FSF's Back-Cover Text is: ``You have freedom to copy and modify
29 this GNU Manual, like GNU software.  Copies published by the Free
30 Software Foundation raise funds for GNU development.''
31 @end quotation
32 @end copying
33
34 @dircategory Software development
35 @direntry
36 * Gnulib: (gnulib).             Source files to share among distributions.
37 @end direntry
38
39 @titlepage
40 @title GNU Gnulib
41 @subtitle updated @value{UPDATED}
42 @author @email{bug-gnulib@@gnu.org}
43 @page
44 @vskip 0pt plus 1filll
45 @insertcopying
46 @end titlepage
47
48 @contents
49
50 @ifnottex
51 @node Top
52 @top GNU Gnulib
53
54 @insertcopying
55 @end ifnottex
56
57 @menu
58 * Gnulib::
59 * Invoking gnulib-tool::
60 * Copying This Manual::
61 * Index::
62 @end menu
63
64
65 @node Gnulib
66 @chapter Gnulib
67
68 This is not a real manual.  It's just a place to store random notes
69 until someone (you?) gets around to actually writing a manual.
70
71 Getting started:
72
73 @itemize
74 @item Gnulib is hosted at Savannah:
75       @url{http://savannah.gnu.org/projects/gnulib}.  Get the sources
76       through CVS from there.
77 @item The Gnulib home page:
78       @url{http://www.gnu.org/software/gnulib/}.
79 @end itemize
80
81 @menu
82 * Comments::
83 * Header files::
84 * ctime::
85 * inet_ntoa::
86 * Out of memory handling::
87 @end menu
88
89 @node Comments
90 @section Comments
91
92 @cindex comments describing functions
93 @cindex describing functions, locating
94 Where to put comments describing functions: Because of risk of
95 divergence, we prefer to keep most function describing comments in
96 only one place: just above the actual function definition.  Some
97 people prefer to put that documentation in the .h file.  In any case,
98 it should appear in just one place unless you can ensure that the
99 multiple copies will always remain identical.
100
101
102 @node Header files
103 @section Header files
104
105 @cindex double inclusion of header files
106 @cindex header file include protection
107 It is a tradition to use CPP tricks to avoid parsing the same header
108 file more than once, which might cause warnings.  The trick is to wrap
109 the content of the header file (say, @file{foo.h}) in a block, as in:
110
111 @example
112 #ifndef FOO_H
113 # define FOO_H
114 ...
115 body of header file goes here
116 ...
117 #endif /* FOO_H */
118 @end example
119
120 Whether to use @code{FOO_H} or @code{_FOO_H} is a matter of taste and
121 style.  The C89 and C99 standards reserve all identifiers that begin with an
122 underscore and either an uppercase letter or another underscore, for
123 any use.  Thus, in theory, an application might not safely assume that
124 @code{_FOO_H} has not already been defined by a library.  On the other
125 hand, using @code{FOO_H} will likely lead the higher risk of
126 collisions with other symbols (e.g., @code{KEY_H}, @code{XK_H}, @code{BPF_H},
127 which are CPP macro constants, or @code{COFF_LONG_H}, which is a CPP
128 macro function).  Your preference may depend on whether you consider
129 the header file under discussion as part of the application (which has
130 its own namespace for CPP symbols) or a supporting library (that
131 shouldn't interfere with the application's CPP symbol namespace).
132
133 @cindex C++ header files
134 @cindex Header files and C++
135 Adapting C header files for use in C++ applications can use another
136 CPP trick, as in:
137
138 @example
139 # ifdef __cplusplus
140 extern "C"
141 @{
142 # endif
143 ...
144 body of header file goes here
145 ...
146 # ifdef __cplusplus
147 @}
148 # endif
149 @end example
150
151 The idea here is that @code{__cplusplus} is defined only by C++
152 implementations, which will wrap the header file in an @samp{extern "C"}
153 block.  Again, whether to use this trick is a matter of taste and
154 style.  While the above can be seen as harmless, it could be argued
155 that the header file is written in C, and any C++ application using it
156 should explicitly use the @samp{extern "C"} block itself.  Your
157 preference might depend on whether you consider the API exported by
158 your header file as something available for C programs only, or for C
159 and C++ programs alike.
160
161 @node ctime
162 @section ctime
163 @findex ctime
164
165 The @code{ctime} function need not be reentrant, and consequently is
166 not required to be thread safe.  Implementations of @code{ctime}
167 typically write the time stamp into static buffer.  If two threads
168 call @code{ctime} at roughly the same time, you might end up with the
169 wrong date in one of the threads, or some undefined string.  There is
170 a re-entrant interface @code{ctime_r}, that take a pre-allocated
171 buffer and length of the buffer, and return @code{NULL} on errors.
172 The input buffer should be at least 26 bytes in size.  The output
173 string is locale-independent.  However, years can have more than 4
174 digits if @code{time_t} is sufficiently wide, so the length of the
175 required output buffer is not easy to determine.  Increasing the
176 buffer size when @code{ctime_r} return @code{NULL} is not necessarily
177 sufficient. The @code{NULL} return value could mean some other error
178 condition, which will not go away by increasing the buffer size.
179
180 A more flexible function is @code{strftime}.  However, note that it is
181 locale dependent.
182
183
184 @node inet_ntoa
185 @section inet_ntoa
186 @findex inet_ntoa
187
188 The @code{inet_ntoa} function need not be reentrant, and consequently
189 is not required to be thread safe.  Implementations of
190 @code{inet_ntoa} typically write the time stamp into static buffer.
191 If two threads call @code{inet_ntoa} at roughly the same time, you
192 might end up with the wrong date in one of the threads, or some
193 undefined string.  Further, @code{inet_ntoa} is specific for
194 @acronym{IPv4} addresses.
195
196 A protocol independent function is @code{inet_ntop}.
197
198
199 @node Out of memory handling
200 @section Out of memory handling
201
202 @cindex Out of Memory handling
203 @cindex Memory allocation failure
204 The GSS API does not have a standard error code for the out of memory
205 error condition.  Instead of adding a non-standard error code, this
206 library has chosen to adopt a different strategy.  Out of memory
207 handling happens in rare situations, but performing the out of memory
208 error handling after almost all API function invocations pollute your
209 source code and might make it harder to spot more serious problems.
210 The strategy chosen improve code readability and robustness.
211
212 @cindex Aborting execution
213 For most applications, aborting the application with an error message
214 when the out of memory situation occur is the best that can be wished
215 for.  This is how the library behaves by default.
216
217 @vindex xalloc_fail_func
218 However, we realize that some applications may not want to have the
219 GSS library abort execution in any situation.  The GSS library support
220 a hook to let the application regain control and perform its own
221 cleanups when an out of memory situation has occured.  The application
222 can define a function (having a @code{void} prototype, i.e., no return
223 value and no parameters) and set the library variable
224 @code{xalloc_fail_func} to that function.  The variable should be
225 declared as follows.
226
227 @example
228 extern void (*xalloc_fail_func) (void);
229 @end example
230
231 The GSS library will invoke this function if an out of memory error
232 occurs.  Note that after this the GSS library is in an undefined
233 state, so you must unload or restart the application to continue call
234 GSS library functions.  The hook is only intended to allow the
235 application to log the situation in a special way.  Of course, care
236 must be taken to not allocate more memory, as that will likely also
237 fail.
238
239
240 @node Invoking gnulib-tool
241 @chapter Invoking gnulib-tool
242
243 @pindex gnulib-tool
244 @cindex invoking @command{gnulib-tool}
245
246 Run @samp{gnulib-tool --help}, and use the source.
247 @command{gnulib-tool} is the way to import Gnulib modules.
248
249 @menu
250 * Initial import::              First import of Gnulib modules.
251 * Importing updated files::     Subsequent imports.
252 * Finishing touches::           Simplifying imports.
253 @end menu
254
255
256 @node Initial import
257 @section Initial import
258 @cindex initial import
259
260 Gnulib assumes your project uses Autoconf and Automake.  Invoking
261 @samp{gnulib-tool --import} will copy source files, create a
262 @file{Makefile.am} to build them, and generate a @file{gnulib.m4} with
263 Autoconf M4 macro declarations used by @file{configure.ac}.
264
265 Our example will be a library that uses Autoconf, Automake and
266 Libtool.  It calls @code{strdup}, and you wish to use gnulib to make
267 the package portable to C89 (which doesn't have @code{strdup}).
268
269 @example
270 ~/src/libfoo$ gnulib-tool --import strdup
271 Module list with included dependencies:
272   strdup
273 File list:
274   lib/strdup.c
275   lib/strdup.h
276   m4/onceonly_2_57.m4
277   m4/strdup.m4
278 Creating ./lib/Makefile.am...
279 Creating ./m4/gnulib.m4...
280 Finished.
281
282 You may need to add #include directives for the following .h files.
283   #include "strdup.h"
284
285 Don't forget to add "lib/Makefile"
286 to AC_CONFIG_FILES in "./configure.ac" and to mention
287 "lib" in SUBDIRS in some Makefile.am.
288 ~/src/libfoo$
289 @end example
290
291 By default, the source code is copied into @file{lib/} and the M4
292 macros in @file{m4/}.  You can override these paths by using
293 @code{--source-base=DIRECTORY} and @code{--m4-base=DIRECTORY}, or by
294 adding @samp{gl_SOURCE_BASE(DIRECTORY)} and
295 @samp{gl_M4_BASE(DIRECTORY)} to your @file{configure.ac}.
296 Some modules also provide other files necessary
297 for building. These files are copied into the directory specified
298 by @samp{AC_CONFIG_AUX_DIR} in @file{configure.ac} or by the
299 @code{--aux-dir=DIRECTORY} option. If neither is specified, the
300 current directory is assumed.
301
302 @code{gnulib-tool} can make symbolic links instead
303 of copying the source files. Use the @code{--symbolic}
304 (or @code{-s} for short) option to do this.
305
306 @code{gnulib-tool} will overwrite any pre-existing files, in
307 particular @file{Makefile.am}.  Unfortunately, separating the
308 generated @file{Makefile.am} content (for building the gnulib library)
309 into a separate file, say @file{gnulib.mk}, that could be included
310 by your handwritten @file{Makefile.am} is not possible, due to how
311 variable assignments are handled by Automake.
312
313 Consequently, it can be a good idea to chose directories that are not
314 already used by your projects, to separate gnulib imported files from
315 your own files.  This approach can also be useful if you want to avoid
316 conflicts between other tools (e.g., @code{getextize} that also copy
317 M4 files into your package.  Simon Josefsson successfully uses a source
318 base of @file{gl/}, and a M4 base of @file{gl/m4/}, in several
319 packages.
320
321 A few manual steps are required to finish the initial import.
322
323 First, you need to make sure Autoconf can find the macro definitions
324 in @file{gnulib.m4}.  Use the @code{ACLOCAL_AMFLAGS} specifier in your
325 top-level @file{Makefile.am} file, as in:
326
327 @example
328 ACLOCAL_AMFLAGS = -I m4
329 @end example
330
331 Naturally, replace @file{m4} with the value from @code{--m4-base} or
332 @code{gl_M4_BASE}.  If the M4 base is @file{gl/m4} you would use:
333
334 @example
335 ACLOCAL_AMFLAGS = -I gl/m4
336 @end example
337
338 You are now ready to call the M4 macros in @code{gnulib.m4} from
339 @file{configure.ac}.  The macro @code{gl_EARLY} must be called as soon
340 as possible after verifying that the C compiler is working.
341 Typically, this is immediately after @code{AC_PROG_CC}, as in:
342
343 @example
344 ...
345 AC_PROG_CC
346 gl_EARLY
347 ...
348 @end example
349
350 The core part of the gnulib checks are done by the macro
351 @code{gl_INIT}.  Place it further down in the file, typically where
352 you normally check for header files or functions.  Or in a separate
353 section with other gnulib statements, such as @code{gl_SOURCE_BASE}.
354 For example:
355
356 @example
357 ...
358 # For gnulib.
359 gl_INIT
360 ...
361 @end example
362
363 You must also make sure that the gnulib library is built.  Add the
364 @code{Makefile} in the gnulib source base directory to
365 @code{AC_CONFIG_FILES}, as in:
366
367 @example
368 AC_CONFIG_FILES(... lib/Makefile ...)
369 @end example
370
371 If your gnulib source base is @file{gl}, you would use:
372
373 @example
374 AC_CONFIG_FILES(... gl/Makefile ...)
375 @end example
376
377 You must also make sure that @code{make} work in the gnulib directory.
378 Add the gnulib source base directory to a @code{SUBDIRS} Makefile.am
379 statement, as in:
380
381 @example
382 SUBDIRS = lib
383 @end example
384
385 or if you, more likely, already have a few entries in @code{SUBDIRS},
386 you can add something like:
387
388 @example
389 SUBDIRS += lib
390 @end example
391
392 If you are using a gnulib source base of @code{gl}, you would use:
393
394 @example
395 SUBDIRS += gl
396 @end example
397
398 Finally, you have add C flags and LD flags, so that you can make use
399 of the gnulib library.  For example:
400
401 @example
402 ...
403 AM_CPPFLAGS = -I$(top_srcdir)/lib
404 ...
405 LIBADD = lib/libgnu.la
406 ...
407 @end example
408
409 Don't forget to @code{#include} the various header files.  In this
410 example, you would need to make sure that @samp{#include <strdup.h>}
411 is evaluated when compiling all source code files, that want to make
412 use of @code{strdup}.
413
414
415 @node Importing updated files
416 @section Importing updated files
417
418 From time to time, you may want to invoke @samp{gnulib-tool --import}
419 to update the files in your package.  Once you have set up your
420 package for gnulib, this step is quite simple.  For example:
421
422 @example
423 ~/src/libfoo$ gnulib-tool --import --source-base gl --m4-base gl/m4 strdup
424 Module list with included dependencies:
425   strdup
426 File list:
427   lib/strdup.c
428   lib/strdup.h
429   m4/onceonly_2_57.m4
430   m4/strdup.m4
431 Creating ./lib/Makefile.am...
432 Creating ./m4/gnulib.m4...
433 Finished.
434
435 Don't forget to add "lib/Makefile"
436 to AC_CONFIG_FILES in "./configure.ac" and to mention
437 "lib" in SUBDIRS in some Makefile.am.
438 ~/src/libfoo$
439 @end example
440
441 If you don't recall how you invoked the tool last time, the commands
442 used (and the operations it resulted in) are placed in comments within
443 the generated @file{Makefile.am} and @file{gnulib.m4}, as in:
444
445 @example
446 ...
447 # Invoked as: gnulib-tool --import strdup
448 # Reproduce by: gnulib-tool --import --dir=. --lib=libgnu --source-base=lib --m4-base=m4 --libtool strdup
449 ...
450 @end example
451
452
453 @node Finishing touches
454 @section Finishing touches
455
456 Invoking @samp{gnulib-tool --import} with the proper parameters (e.g.,
457 @samp{--m4-base gl/m4}) and list of modules (e.g., @samp{strdup
458 snprintf getline minmax}) can be tedious.  To simplify this procedure,
459 you may put the command line parameters in your @file{configure.ac}.
460 For example:
461
462 @example
463 ...
464 AC_PROG_CC
465 gl_EARLY
466 ...
467 # For gnulib.
468 gl_SOURCE_BASE(gl)
469 gl_M4_BASE(gl/m4)
470 gl_LIB(libgl)
471 gl_MODULES(getopt progname strdup dummy exit error getpass-gnu getaddrinfo)
472 gl_INIT
473 ...
474 @end example
475
476 This illustrate all macros defined in @file{gnulib.m4}.  With the
477 above, importing new files are as simple as running @samp{gnulib-tool
478 --import} with no additional parameters.
479
480 The macros @code{gl_EARLY}, @code{gl_INIT}, @code{gl_SOURCE_BASE}, and
481 @code{gl_M4_BASE} have been discussed earlier.  The @code{gl_LIB}
482 macro can be used if you wish to change the library name (by default
483 @file{libgnu.a} or @file{libgnu.la} if you use libtool).  The
484 @code{gl_MODULES} macro is used to specify which modules to import.
485
486
487 @node Copying This Manual
488 @appendix Copying This Manual
489
490 @menu
491 * GNU Free Documentation License::  License for copying this manual.
492 @end menu
493
494 @include fdl.texi
495
496
497 @node Index
498 @unnumbered Index
499
500 @printindex cp
501
502 @bye