c61ab571a7dd11a60c41e55c7de9f733141e258d
[gnulib.git] / doc / gnulib.texi
1 \input texinfo   @c -*-texinfo-*-
2 @comment $Id: gnulib.texi,v 1.22 2006-06-19 20:40:26 karl 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: 2006-06-19 20:40:26 $
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, 2005, 2006 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 manual contains some bare-bones documentation, but not much more.
69 It's mostly been a place to store notes until someone (you?)@ gets
70 around to writing a coherent manual.
71
72 Getting started:
73
74 @itemize
75 @item Gnulib is hosted at Savannah:
76       @url{http://savannah.gnu.org/projects/gnulib}.  Get the sources
77       through CVS from there.
78 @item The Gnulib home page:
79       @url{http://www.gnu.org/software/gnulib/}.
80 @end itemize
81
82 @menu
83 * Comments::
84 * Header files::
85 * Quoting::
86 * ctime::
87 * inet_ntoa::
88 * gcd::
89 * Out of memory handling::
90 * Library version handling::
91 * Regular expressions::
92 @end menu
93
94
95 @node Comments
96 @section Comments
97
98 @cindex comments describing functions
99 @cindex describing functions, locating
100 Where to put comments describing functions: Because of risk of
101 divergence, we prefer to keep most function describing comments in
102 only one place: just above the actual function definition.  Some
103 people prefer to put that documentation in the .h file.  In any case,
104 it should appear in just one place unless you can ensure that the
105 multiple copies will always remain identical.
106
107
108 @node Header files
109 @section Header files
110
111 @cindex double inclusion of header files
112 @cindex header file include protection
113 It is a tradition to use CPP tricks to avoid parsing the same header
114 file more than once, which might cause warnings.  The trick is to wrap
115 the content of the header file (say, @file{foo.h}) in a block, as in:
116
117 @example
118 #ifndef FOO_H
119 # define FOO_H
120 ...
121 body of header file goes here
122 ...
123 #endif /* FOO_H */
124 @end example
125
126 Whether to use @code{FOO_H} or @code{_FOO_H} is a matter of taste and
127 style.  The C89 and C99 standards reserve all identifiers that begin with an
128 underscore and either an uppercase letter or another underscore, for
129 any use.  Thus, in theory, an application might not safely assume that
130 @code{_FOO_H} has not already been defined by a library.  On the other
131 hand, using @code{FOO_H} will likely lead the higher risk of
132 collisions with other symbols (e.g., @code{KEY_H}, @code{XK_H}, @code{BPF_H},
133 which are CPP macro constants, or @code{COFF_LONG_H}, which is a CPP
134 macro function).  Your preference may depend on whether you consider
135 the header file under discussion as part of the application (which has
136 its own namespace for CPP symbols) or a supporting library (that
137 shouldn't interfere with the application's CPP symbol namespace).
138
139 @cindex C++ header files
140 @cindex Header files and C++
141 Adapting C header files for use in C++ applications can use another
142 CPP trick, as in:
143
144 @example
145 # ifdef __cplusplus
146 extern "C"
147 @{
148 # endif
149 ...
150 body of header file goes here
151 ...
152 # ifdef __cplusplus
153 @}
154 # endif
155 @end example
156
157 The idea here is that @code{__cplusplus} is defined only by C++
158 implementations, which will wrap the header file in an @samp{extern "C"}
159 block.  Again, whether to use this trick is a matter of taste and
160 style.  While the above can be seen as harmless, it could be argued
161 that the header file is written in C, and any C++ application using it
162 should explicitly use the @samp{extern "C"} block itself.  Your
163 preference might depend on whether you consider the API exported by
164 your header file as something available for C programs only, or for C
165 and C++ programs alike.
166
167 @subheading Include ordering
168
169 When writing a gnulib module, or even in general, a good way to order
170 the @samp{#include} directives is the following.
171
172 @itemize
173 @item First comes the #include "..." specifying the module being implemented.
174 @item Then come all the #include <...> of system or system-replacement headers,
175 in arbitrary order.
176 @item Then come all the #include "..." of gnulib and private headers, in
177 arbitrary order.
178 @end itemize
179
180
181 @include quote.texi
182
183 @include ctime.texi
184
185 @include gcd.texi
186
187 @include inet_ntoa.texi
188
189
190 @node Out of memory handling
191 @section Out of memory handling
192
193 @cindex Out of Memory handling
194 @cindex Memory allocation failure
195 The GSS API does not have a standard error code for the out of memory
196 error condition.  Instead of adding a non-standard error code, this
197 library has chosen to adopt a different strategy.  Out of memory
198 handling happens in rare situations, but performing the out of memory
199 error handling after almost all API function invocations pollute your
200 source code and might make it harder to spot more serious problems.
201 The strategy chosen improve code readability and robustness.
202
203 @cindex Aborting execution
204 For most applications, aborting the application with an error message
205 when the out of memory situation occur is the best that can be wished
206 for.  This is how the library behaves by default.
207
208 @vindex xalloc_fail_func
209 However, we realize that some applications may not want to have the
210 GSS library abort execution in any situation.  The GSS library support
211 a hook to let the application regain control and perform its own
212 cleanups when an out of memory situation has occured.  The application
213 can define a function (having a @code{void} prototype, i.e., no return
214 value and no parameters) and set the library variable
215 @code{xalloc_fail_func} to that function.  The variable should be
216 declared as follows.
217
218 @example
219 extern void (*xalloc_fail_func) (void);
220 @end example
221
222 The GSS library will invoke this function if an out of memory error
223 occurs.  Note that after this the GSS library is in an undefined
224 state, so you must unload or restart the application to continue call
225 GSS library functions.  The hook is only intended to allow the
226 application to log the situation in a special way.  Of course, care
227 must be taken to not allocate more memory, as that will likely also
228 fail.
229
230
231 @node Library version handling
232 @section Library version handling
233
234 The module @samp{check-version} can be useful when your gnulib
235 application is a system library.  You will typically wrap the call to
236 the @code{check_version} function through a library API, your library
237 header file may contain:
238
239 @example
240 #define STRINGPREP_VERSION "0.5.18"
241 ...
242   extern const char *stringprep_check_version (const char *req_version);
243 @end example
244
245 To avoid ELF symbol collisions with other libraries that use the
246 @samp{check-version} module, add to @file{config.h} through a
247 AC_DEFINE something like:
248
249 @example
250 AC_DEFINE(check_version, stringprep_check_version,
251           [Rename check_version.])
252 @end example
253
254 The @code{stringprep_check_version} function will thus be implemented
255 by the @code{check_version} module.
256
257 There are two uses of the interface.  The first is a way to provide
258 for applications to find out the version number of the library it
259 uses.  The application may contain diagnostic code such as:
260
261 @example
262   printf ("Stringprep version: header %s library %s",
263           STRINGPREP_VERSION,
264           stringprep_check_version (NULL));
265 @end example
266
267 Separating the library and header file version can be useful when
268 searching for version mismatch related problems.
269
270 The second uses is as a rudimentary test of proper library version, by
271 making sure the application get a library version that is the same, or
272 newer, than the header file used when building the application.  This
273 doesn't catch all problems, libraries may change backwards incompatibly
274 in later versions, but enable applications to require a certain
275 minimum version before it may proceed.
276
277 Typical uses look like:
278
279 @example
280        /* Check version of libgcrypt. */
281        if (!gcry_check_version (GCRYPT_VERSION))
282          die ("version mismatch\n");
283 @end example
284
285
286 @node Regular expressions
287 @section Regular expressions
288
289 Gnulib supports many different types of regular expressions; although
290 the underlying features are the same or identical, the syntax used
291 varies.  The descriptions given here for the different types are
292 generated automatically.
293
294 @include regexprops-generic.texi
295
296
297 @include gnulib-tool.texi
298
299
300 @node Copying This Manual
301 @appendix Copying This Manual
302
303 @menu
304 * GNU Free Documentation License::  License for copying this manual.
305 @end menu
306
307 @include fdl.texi
308
309
310 @node Index
311 @unnumbered Index
312
313 @printindex cp
314
315 @bye